Javascript变量似乎是静态的

时间:2013-09-14 15:52:16

标签: javascript php jquery ajax jquery-autocomplete

我正在尝试开发一个用PHP编写的网站,其中包含一个用户用它在网站上注册的页面。 在选择此页面的国家/地区部分时,我正在尝试使用LOOPJ(http://loopj.com/jquery-tokeninput/demo.html)jQuery自动完成脚本。 当我尝试搜索并提出建议列表时,我想发送另一个字段的数据,该数据位于表单的文本框中。所以我尝试使用以下代码:

    $(document).ready(function() {
        var countryfrom = $("input#country2").val();
        $("#city-input-custom-limits").tokenInput("autocomplete/city_search.php?country=" + countryfrom, {
            searchDelay: 1000,
            minChars: 3,
            tokenLimit: 1
        });
    });

一切都很好。但是,当我更改“country2”文本框值时,countryfrom的值不会更改,country2的初始值将返回city_search.php页面。

有人可以提出建议countryfrom值在country2更改时不会发生变化的原因吗?

1 个答案:

答案 0 :(得分:3)

你应该听keyup事件:

// Cache the element
var $elem = $("#city-input-custom-limits");

$("#country2").on('keyup', function() {
     var country = $.trim(this.value);
     $elem.tokenInput("autocomplete/city_search.php?country=" + country, {
         searchDelay: 1000,
         minChars: 3,
         tokenLimit: 1
     });
}).triggerHandler('keyup'); // execute the handler on DOM ready