最新消息:雨落星辰是一个专注网站SEO优化、网站SEO诊断、搜索引擎研究、网络营销推广、网站策划运营及站长类的自媒体原创博客

javascript - Autocomplete search box and pass value to flask - Stack Overflow

programmeradmin3浏览0评论

I am preparing a demo and this is the first time I am doing "web dev". So, might be totally a noob question but here is what I am trying to do.

I want to have two search boxes which autopletes as typing.

First search box: name
Second search box: song

I have two files names.txt and songs.txt

So, the idea is that when the user is typing name, it is reading from names.txt to generate the autoplete and when user is typing song, the search box autopletes based on songs.txt

And then these values are passed to flask app in backend..

@app.route('/search', method=['post'])
def process():
  return name, song, and list of other songs with score (list a table)

I need like a very simple example (nothing fancy) which just does this..

Thanks

I am preparing a demo and this is the first time I am doing "web dev". So, might be totally a noob question but here is what I am trying to do.

I want to have two search boxes which autopletes as typing.

First search box: name
Second search box: song

I have two files names.txt and songs.txt

So, the idea is that when the user is typing name, it is reading from names.txt to generate the autoplete and when user is typing song, the search box autopletes based on songs.txt

And then these values are passed to flask app in backend..

@app.route('/search', method=['post'])
def process():
  return name, song, and list of other songs with score (list a table)

I need like a very simple example (nothing fancy) which just does this..

Thanks

Share Improve this question asked Sep 21, 2016 at 10:56 frazmanfrazman 33.3k81 gold badges193 silver badges281 bronze badges 2
  • Do you have the autoplete boxes posting automatically? You just need help constructing the flask api to return the data? – GMarsh Commented Sep 21, 2016 at 13:09
  • @GMarsh no.. I need the Javascript part too – frazman Commented Sep 21, 2016 at 16:16
Add a ment  | 

1 Answer 1

Reset to default 9

How about using jQuery-Autoplete. This should get you started:

**/app.py**

from flask import Flask, request, render_template, jsonify
app = Flask(__name__)

@app.route("/")
def index():
    return render_template("index.html")

@app.route("/search/<string:box>")
def process(box):
    query = request.args.get('query')
    if box == 'names':
        # do some stuff to open your names text file
        # do some other stuff to filter
        # put suggestions in this format...
        suggestions = [{'value': 'joe','data': 'joe'}, {'value': 'jim','data': 'jim'}]
    if box == 'songs':
        # do some stuff to open your songs text file
        # do some other stuff to filter
        # put suggestions in this format...
        suggestions = [{'value': 'song1','data': '123'}, {'value': 'song2','data': '234'}]
    return jsonify({"suggestions":suggestions})

if __name__ == "__main__":
    app.run(debug=True)

**/templates/index.html**

<head>
  <script src="https://cdnjs.cloudflare./ajax/libs/jquery/3.1.0/jquery.min.js"></script>
  <script src="https://cdnjs.cloudflare./ajax/libs/jquery.devbridge-autoplete/1.2.26/jquery.autoplete.min.js"></script>
</head>

<body>
  Names:
  <input type="text" name="names" id="autoplete1"/>

  Songs:
  <input type="text" name="songs" id="autoplete2"/>


  <script>
  $('#autoplete1').autoplete({
      serviceUrl: '/search/names',
      dataType: 'json',
      onSearchComplete: function (query, suggestions) {
        console.log(query);
      }
  });

  $('#autoplete2').autoplete({
      serviceUrl: '/search/songs',
      dataType: 'json',
      onSearchComplete: function (query, suggestions) {
        console.log(query);
      }
  });
  </script>
</body>
发布评论

评论列表(0)

  1. 暂无评论
ok 不同模板 switch ($forum['model']) { /*case '0': include _include(APP_PATH . 'view/htm/read.htm'); break;*/ default: include _include(theme_load('read', $fid)); break; } } break; case '10': // 主题外链 / thread external link http_location(htmlspecialchars_decode(trim($thread['description']))); break; case '11': // 单页 / single page $attachlist = array(); $imagelist = array(); $thread['filelist'] = array(); $threadlist = NULL; $thread['files'] > 0 and list($attachlist, $imagelist, $thread['filelist']) = well_attach_find_by_tid($tid); $data = data_read_cache($tid); empty($data) and message(-1, lang('data_malformation')); $tidlist = $forum['threads'] ? page_find_by_fid($fid, $page, $pagesize) : NULL; if ($tidlist) { $tidarr = arrlist_values($tidlist, 'tid'); $threadlist = well_thread_find($tidarr, $pagesize); // 按之前tidlist排序 $threadlist = array2_sort_key($threadlist, $tidlist, 'tid'); } $allowpost = forum_access_user($fid, $gid, 'allowpost'); $allowupdate = forum_access_mod($fid, $gid, 'allowupdate'); $allowdelete = forum_access_mod($fid, $gid, 'allowdelete'); $access = array('allowpost' => $allowpost, 'allowupdate' => $allowupdate, 'allowdelete' => $allowdelete); $header['title'] = $thread['subject']; $header['mobile_link'] = $thread['url']; $header['keywords'] = $thread['keyword'] ? $thread['keyword'] : $thread['subject']; $header['description'] = $thread['description'] ? $thread['description'] : $thread['brief']; $_SESSION['fid'] = $fid; if ($ajax) { empty($conf['api_on']) and message(0, lang('closed')); $apilist['header'] = $header; $apilist['extra'] = $extra; $apilist['access'] = $access; $apilist['thread'] = well_thread_safe_info($thread); $apilist['thread_data'] = $data; $apilist['forum'] = $forum; $apilist['imagelist'] = $imagelist; $apilist['filelist'] = $thread['filelist']; $apilist['threadlist'] = $threadlist; message(0, $apilist); } else { include _include(theme_load('single_page', $fid)); } break; default: message(-1, lang('data_malformation')); break; } ?>