使此 jQuery 函数动态化

Make this jQuery function dynamic

本文关键字:动态化 函数 jQuery 使此      更新时间:2023-09-26

我正在尝试使用LoopJ(http://loopj.com/jquery-tokeninput/demo.html)自动编译来创建功能搜索框。正如您在演示页上看到的,以下代码运行自动完成:

$(document).ready(function() {
    $("#demo-input-pre-populated").tokenInput("tvshows.php", {
         searchDelay: 1000,
         minChars: 3,
         tokenLimit: 1,        
         prePopulate: [
            {id: 9000, name: "Kriss Akabusi"}
         ]
            });
    });

假设您要将文本框值作为 GET 请求发送到 tvshows.php 。由于此代码只会获取文本框的初始值(假设id=mytextbox),因此我尝试编辑此代码以使其在文本框值更改时满足我的要求:

var $elem = $("#demo-input-pre-populated");
$("#mytextbox").on('change', function() {
     var country = $.trim(this.value);
     $elem.tokenInput("tvshows.php?country=" + country, {
         searchDelay: 1000,
         minChars: 3,
         tokenLimit: 1,
     });
});

而且效果很好。那么,问题出在哪里呢?

正如您在 JavaScript 代码中看到的,我删除了第二个 JS 代码prePopulate(prePopulate 是搜索框的默认值)。由于在我更改文本框的值之前不会设置prePopulate - 通过在文本框中键入一些内容 (id= mytextbox )。

那么,我怎样才能一起处理所有这些东西呢?在更改文本框的值之前,我尝试了不同的方法来使prePopulate工作。但我仍然没有成功。

您可以使用onAdd函数来执行此操作

var $elem = $("#demo-input-pre-populated");
var arr = [];//Array to hold selected values
$("#mytextbox").on('change', function() {
     var country = $.trim(this.value);
     $elem.tokenInput("tvshows.php?country=" + country, {
         searchDelay: 1000,
         minChars: 3,
         tokenLimit: 1,
         prePopulate: arr,
         onAdd:function(item)
           {
              arr.push(item);
           }
     });
});