无法绑定jquery下拉列表

时间:2013-04-17 12:00:13

标签: jquery asp.net ajax

我有功能,我试图将返回值附加到下拉列表,但它根本没有帮助。

这是我的功能

function GetNames(FROM,TO) {
 var inputObject = {};   
 inputObject.FROM = FROM;   
  inputObject.TO = TO;    
 $.ajax({   
     type: "POST",  
      url: "../WebService.asmx/getName",   
      data: {from : inputObject.FROM ,to : inputObject.TO},   
      contentType: "application/json; charset=utf-8",   
      dataType: "json",   
      async: true,   
      success: function (msg) {   
        $.each(msg.d, function (k, value) {   
            $('#ddlName').append("<option value='" + value + "'>" + value + "   </option>");   
        });   
     },   
         error: function (errMsg) {   
         alert(errMsg);   
     }   
  });   
}

我已将数据参数更改为此值,但它们没有帮助

1) data: JSON.stringify(inputObject),
2) data: {'from=' : inputObject.FROM, 'to=' : inputObject.TO},
3) data: {'from' : inputObject.FROM, 'to' : inputObject.TO},

这些变化都没有帮助。

FROM和TO是我测试webservice getName方法及其工作正常的日期。 但是这个javascript方法一直存在错误:函数(errMsg)和消息“Object:Object”

Web服务方法:

  [WebMethod]
    public List<string> getName(string from,string to)
    {
        List<string> bdnames= new List<string>();
        try
        {
            DataSet ds = null;
            SqlParameter[] sqlparams = new SqlParameter[2];


            sqlparams[0] = new SqlParameter("@FROM", SqlDbType.DateTime);
            sqlparams[0].Direction = ParameterDirection.Input;
            sqlparams[0].Value = Convert.ToDateTime(from);

            sqlparams[1] = new SqlParameter("@TO", SqlDbType.DateTime);
            sqlparams[1].Direction = ParameterDirection.Input;
            sqlparams[1].Value = Convert.ToDateTime(to);

            ds = SqlHelper.ExecuteDataset(usmHelper.ConnectionString, CommandType.StoredProcedure, "rep_getBDMs", sqlparams);

            for (int i = 0; i < ds.Tables[0].Rows.Count; i++)
            {
                bdnames.Add(ds.Tables[0].Rows[i]["UUMM"].ToString());
            }
        }
        catch(Exception ex)
        {

        }
        finally
        {

        }
        return bdnames;
    }

Web服务返回值

<?xml version="1.0" encoding="utf-8" ?> 
- <ArrayOfString xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:xsd="http://www.w3.org/2001/XMLSchema" xmlns="http://tempuri.org/">
  <string>Samuel</string> 
  <string>Chetna</string> 
  <string>Chris</string> 
  <string>Mily</string> 
  <string>tuff</string> 
  <string>Prasad</string> 
  <string>Ram</string> 
  <string>Gary</string> 
  <string>MarkTaylor</string> 
  <string>Kenn</string> 
  </ArrayOfString>

1 个答案:

答案 0 :(得分:0)

这是一个非常详细的版本,但您可能会发现一些价值:

function GetNames(FROM, TO) {
    // just use the object you created for data
    var inputObject = {
        from: FROM,
        to: TO
    };
    $.ajax({
        type: "POST",
        url: "../WebService.asmx/getName",
        data: inputObject,
        contentType: "application/json",
        dataType: "json",
        async: true,
        // figure out if it has .d or not and filter for that
        dataFilter: function (data) {
            var msg;
            if (typeof (JSON) !== 'undefined' && typeof (JSON.parse) === 'function') msg = JSON.parse(data);
            else msg = jQuery.parseJSON(data);
            if (msg.hasOwnProperty('d')) return msg.d;
            else return msg;
        },
        // pass the filtered message (data returned) to a function
        success: function (msg) {
            loadOptions(msg);
        },
        // verbose error handler
        error: function (xhr, textStatus, errorThrown) {
            var errorMessage = "Ajax error: " + this.url + " : " + textStatus + " : " + errorThrown + " : " + xhr.statusText + " : " + xhr.status;
            alert(errorMessage);
            if (xhr.status != "0" || errorThrown != "abort") {
                alert(errorMessage);
            }
        }

    });
}
/* build the option list 
   This only hits the DOM once instead of your .each or  a .map etc.
*/
function loadOptions(jdata) {
    var bdnames = jdata.bdnames;
    var options = '';
    for (var i = 0; i < bdnames.length; i++) {
        options += '<option value="' + bdnames[i].string + '">' + bdnames[i].string + '</option>';
    }
    $("select#ddlName").html(options);
}