今天遇到一个问题,我需要传一个文本库的内容给后台,然后用autocomplete显示内容,开始觉得很简单
不就是
function SalePrice_Complete(text) { //分割拿到索引 var value=$("#MaterielID_" + text.selector.split('_')[1]).val(); text.autocomplete("/Control/webControl.ashx", { dataType: 'json', //返回数据类型 width: 220, minChars: 0, extraParams: { Method: "SalePriceAutoComplate",MaterielID:value}, parse: function (data) { //后台返回的数据传给自定义的rows var rows = []; for (var i = 0; i < data.length; i++) { rows[rows.length] = { data: "[" + data[i].FPirce + " " + data[i].FDate + "]", //显示在搜索界面的列表 value: data[i].FPirce , //查询结果 result: data[i].FPirce //显示在文本框的内容 }; } return rows; }, formatItem: function (row, i, n) { return row; } }).result(function (event, item, returnvalue) { var values = returnvalue; var index = text[0].id; var i = index.split('_')[1]; //物料编号 $("#price_" + i).val(values[0]); }); };
但是代码运行后发现,MaterielID得到是空的,想了很久不知道为什么,于是在后台和js都下了断点,再运行,发现js没有再运行过了,但是后台却断点断到了
所以我们可以推断,变量是要动态赋值的
于是参考了下网上的代码,修改成
function SalePrice_Complete(text) { text.autocomplete("/Control/webControl.ashx", { dataType: 'json', //返回数据类型 width: 220, minChars: 0, extraParams: { Method: "SalePriceAutoComplate",MaterielID:function(){ return $("#MaterielID_" + text.selector.split('_')[1]).val()}}, parse: function (data) { //后台返回的数据传给自定义的rows var rows = []; for (var i = 0; i < data.length; i++) { rows[rows.length] = { data: "[" + data[i].FPirce + " " + data[i].FDate + "]", //显示在搜索界面的列表 value: data[i].FPirce , //查询结果 result: data[i].FPirce //显示在文本框的内容 }; } return rows; }, formatItem: function (row, i, n) { return row; } }).result(function (event, item, returnvalue) { var values = returnvalue; var index = text[0].id; var i = index.split('_')[1]; //物料编号 $("#price_" + i).val(values[0]); }); };
这样后台拿到MaterielID就有值了,事实证明,在对代码机制不熟悉的情况下,用正常思维去推只能让你陷入烦恼和气愤中,想着明明有赋值,怎么到后台就不见了,所以还是多用断点多调试,用事实说话