alert("data going into $hidden: " + selected.data[1]);
hidden.val(selected.data[1]);
alert("data now in $hidden: " + $hidden.val());
上面最后一行中的$ hidden.val()会返回undefined是什么原因?我已经验证了selected.data [1]包含一个整数值。需要帮助理解jQuery .val()函数
编辑#1:每个评论的一些额外的背景:($隐藏的是一个隐藏的输入域)
$.fn.extend({
autocomplete: function(urlOrData, hidden, options) {
var isUrl = typeof urlOrData == "string";
var $hidden = $(hidden);
options = $.extend({}, $.Autocompleter.defaults, {
url: isUrl ? urlOrData : null,
data: isUrl ? null : urlOrData,
delay: isUrl ? $.Autocompleter.defaults.delay : 10,
max: options && !options.scroll ? 10 : 150
}, options);
// if highlight is set to false, replace it with a do-nothing function
options.highlight = options.highlight || function(value) { return value; };
// if the formatMatch option is not specified, then use formatItem for backwards compatibility
options.formatMatch = options.formatMatch || options.formatItem;
return this.each(function() {
new $.Autocompleter(this, options, $hidden);
});
和...
$.Autocompleter = function(input, options, $hidden) {
//...
function selectCurrent() {
var selected = select.selected();
if (!selected)
return false;
var v = selected.result;
previousValue = v;
if (options.multiple) {
var words = trimWords($input.val());
if (words.length > 1) {
v = words.slice(0, words.length - 1).join(options.multipleSeparator) + options.multipleSeparator + v;
}
v += options.multipleSeparator;
}
alert("data going into $hidden: " + selected.data[1]);
$hidden.val(selected.data[1]);
alert("data now in $hidden: " + $hidden.val());
编辑#2:更多细节....我试图使用多个文本框控件(每个实现自动完成)的窗体上使用jQuery自动完成扩展。每个文本框旁边的表单上都有一个单独的按钮,用于将表单提交给处理函数,该函数需要查找所选项目的值并将其保存到数据库。我想这样做的方式是在表单上包含一个隐藏字段来保存选定的值。
你在哪里设置$ hidden? – 2009-03-02 16:46:06
我们需要知道$ hidden是指什么才能回答这个问题 – 2009-03-02 16:50:54