关于Ajax下拉菜单中出现“回发或回调参数无效”的解决方案

这两天在开发的时候遇到一个这样的问题,
回发或回调参数无效。在配置中使用 <pages enableEventValidation="true"/> 或在页面中使用 <%@ Page EnableEventValidation="true" %> 启用了事件验证。出于安全目的,此功能验证回发或回调事件的参数是否来源于最初呈现这些事件的服务器控件。如果数据有效并且是预期的,则使用 ClientScriptManager.RegisterForEventValidation 方法来注册回发或回调数据以进行验证。 

在网上找了两天资料都没有结果
剑气潇潇   的文章中看到原因是:
下边引用自:剑气潇潇  的文章
http://www.cnblogs.com/asp600/archive/2006/11/04/550216.aspx

目前为止遇到的出现情况有两种:
一是Form嵌套,一个页面只能有一个Form,仔细检查代码就可以解决。
二是在下拉菜单中使用ajax,常见于省市联动菜单,可能是由于在aspx页面赋给了下拉菜单初始Item值,在事件回发时提示该错误,将下拉菜单初始Item值删除,在绑定事件中添加Item项。


后来我自己发现,问题还不是出在那儿.
原因是 DropDownList 控件的ListItem 的Value 属性 包含汉字.只要将Value 改为英文或数字的就行了.
网上还有一种解决办法:把 EnableEventValidation 属性设置为false;但是这样只是没有警告框而已.数据仍然无法传递给服务器,导致SelectedIndex 值一直为零.

最好在web.config中添加如下语句:
<globalization requestEncoding="utf-8" responseEncoding="utf-8" culture="zh-CN" uiCulture="zh-CN"/>
结果搞定,现在贴到这里希望对大家能够有所帮助.

看来ajax.net对中文支持有限啊,还是因为要在Web.Config设置一下编码??????
 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
下拉菜单是网页常见的交互元素之一,可以让用户方便地选择所需的选项。使用 Ajax 技术实现下拉菜单可以在不刷新整个页面的情况下动态加载数据和更新页面内容,提高用户体验。 下面是一个简单的示例,演示如何使用 Ajax 技术实现下拉菜单: HTML 代码: ``` <select id="select1"> <option value="">请选择</option> <option value="1">选项1</option> <option value="2">选项2</option> <option value="3">选项3</option> </select> <select id="select2"> <option value="">请选择</option> </select> ``` JS 代码: ``` // 获取第一个下拉菜单 var select1 = document.getElementById("select1"); // 监听 select1 的 change 事件,当选项改变时触发 select1.addEventListener("change", function() { // 获取选 var selectedValue = select1.value; // 如果选为空,则清空第二个下拉菜单 if (selectedValue === "") { document.getElementById("select2").innerHTML = "<option value=''>请选择</option>"; return; } // 发送 Ajax 请求获取第二个下拉菜单的选项 var xhr = new XMLHttpRequest(); xhr.onreadystatechange = function() { if (xhr.readyState === 4 && xhr.status === 200) { // 解析服务器返回的数据 var options = JSON.parse(xhr.responseText); // 构建第二个下拉菜单的选项 var html = "<option value=''>请选择</option>"; options.forEach(function(option) { html += "<option value='" + option.value + "'>" + option.label + "</option>"; }); // 更新第二个下拉菜单 document.getElementById("select2").innerHTML = html; } }; xhr.open("GET", "getOptions.php?selectedValue=" + selectedValue); xhr.send(); }); ``` 在上面的代码,我们首先获取了第一个下拉菜单,并监听其 change 事件。当用户选择了一个选项时,我们获取其选,并发送 Ajax 请求到服务器端获取第二个下拉菜单的选项。服务器端可以使用 PHP 等语言处理请求,并返回一个 JSON 数据,其包含了第二个下拉菜单的选项。在客户端收到服务器返回的数据后,我们解析 JSON 数据,构建第二个下拉菜单的选项,并更新页面内容。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值