zoukankan      html  css  js  c++  java
  • jquery.autocomplete 传参问题

    今天遇到一个问题,我需要传一个文本库的内容给后台,然后用autocomplete显示内容,开始觉得很简单

    不就是

    function SalePrice_Complete(text) {
             //分割拿到索引
              var value=$("#MaterielID_" + text.selector.split('_')[1]).val();
                text.autocomplete("/Control/webControl.ashx",
                       {
                           dataType: 'json', //返回数据类型
                            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', //返回数据类型
                            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就有值了,事实证明,在对代码机制不熟悉的情况下,用正常思维去推只能让你陷入烦恼和气愤中,想着明明有赋值,怎么到后台就不见了,所以还是多用断点多调试,用事实说话

  • 相关阅读:
    【CF1027C】Minimum Value Rectangle(贪心,数学)
    【CF1027B】Numbers on the Chessboard(数学)
    【CF1027A】Palindromic Twist(模拟)
    【CF1023C】Bracket Subsequence(模拟)
    【CF1023B】Pair of Toys(解方程)
    【CF1023A】Single Wildcard Pattern Matching(模拟)
    【CF1020C】Elections(贪心)
    【CF1020B】Badge(模拟)
    【CF1020A】New Building for SIS(签到)
    【CF1017D】The Wu(状压前缀和)
  • 原文地址:https://www.cnblogs.com/linyijia/p/3533362.html
Copyright © 2011-2022 走看看