如何解决在ASP.NET C#
我使用WebMethod(服务)绑定下拉列表 我有多个下拉列表,并且需要相互依赖,就像下拉列表的级联一样相互绑定,但是在传递一个选定值的值时,在我的Web方法上调试时显示为空
WebMethod:
public static List<Company> GetCompanies(string CountryCode,string CompanyCode)
{
GetinitiatorList.MasterDataServiceClient oClient = new GetinitiatorList.MasterDataServiceClient();
Almarai.GiveAway.GetinitiatorList.ALM_COMPANY_M[] initiatorsList = oClient.GetActiveCompanies(CountryCode,CompanyCode) List<Company> Companyes = new List<Company>();
foreach (Almarai.GiveAway.GetinitiatorList.ALM_COMPANY_M company in initiatorsList)
{
Companyes.Add(new Company()
{
CountryCode = company.CompanyCode,CompanyName = company.CompanyName
});
}
return Companyes;
}
jQuery
$('#ddlCountry').change(function (e) {
var selectedCountry = $('#ddlCountry').val();
$.ajax({
type: "POST",url: "Header.aspx/GetCompanies",data: JSON.stringify({ CountryCode: selectedCountry,CompanyCode: 'SAU' }),dataType: "json",contentType: "application/json",success: function (res) {
$.each(res.d,function (data,value) {
$("#ddlCompany").append($("<option></option>").val(value.CompanyId).html(value.CompanyName));
$('#ddlCompany').change(function (e) {
Aspx:
<div class="col-md-8">
<select id="ddlCountry">
<option value="0">--Select Country--</option>
</select>
</div>
解决方法
要从下拉列表中获取当前选择的值:
$('#ddlCountry').val();
要从下拉列表中获取当前选定的文本:
$('#ddlCountry :selected').text();
您可以先通过在ajax调用中指定以下内容发送硬编码文本,来检查ajax调用是否正常工作:
$.ajax({
type: "POST",url: "Header.aspx/GetCompanies",data: JSON.stringify({ CountryCode: 'USA',CompanyCode: 'SAU' })
....
然后您可以检查是否正确分配了下拉值?如果只希望文本不值钱,那么可以使用我上面提到的内容。我认为它将解决您的问题。如果不是,请告诉我。
============更新(阅读评论后)====================
我已经根据您的样本创建了样本演示。由于我没有您所拥有的服务代码,因此很容易对其进行测试以检查其是否正常工作,否则将给我与您相同的错误。
我为测试所做的工作对您来说似乎微不足道,但请检查,它对我有用,并给我正确的结果。这是Route Config文件的屏幕截图,请看一下红色圆圈(对于Web方法,我必须更改它)
chrome开发工具的屏幕截图(为简单起见,此处为Contact.aspx页面)
最后是Contact.aspx-> GetCompanies Web方法断点命中的屏幕快照,在这里我为了简单起见修改了方法主体,只是为了检查数据绑定是否起作用。
所以,它对我有用。请您一步步检查所有步骤,并告诉我。如果能帮到您,那将是我的荣幸。
,我认为您不需要对它进行分类。
代替:
data: JSON.stringify({ CountryCode: selectedCountry,CompanyCode: 'SAU' }),
尝试:
data: { CountryCode: selectedCountry,CompanyCode: 'SAU' },
,
您是否需要.aspx后缀?
Try like this url: "Header/GetCompanies",
,
我在这里错过了一个非常愚蠢的问题,从网络方法中我正返回CompanyCode
,如您所见
CountryCode = company.CompanyCode, CompanyName = company.CompanyName
在HTML中,我试图绑定CompanyId
,如您在此处看到的那样:
$("#ddlCompany").append($("<option></option>").val(value.CompanyId).html(value.CompanyName));
因此,明显的区域为null或0。
我只需将value.CompanyId
替换为CompanyCode
,它现在可以正常工作
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。