用DropDownList實現Ajax無重新整理省市三級聯動中出現的錯誤

來源:互聯網
上載者:User

目標:用服務端控制項DropDownList實現Ajax無重新整理省市三級聯動

省:<asp:DropDownList ID="ddlProvince" runat="server"  EnableViewState="false"></asp:DropDownList>
市:<asp:DropDownList ID="ddlCity" runat="server"  EnableViewState="false"></asp:DropDownList>
區:<asp:DropDownList ID="ddlCounty" runat="server"  EnableViewState="false"></asp:DropDownList>

 

做法:

頁面載入時首先載入“省”的資料,然後給市和區分別加上“請選擇”的項,用JQuery的$.post()方法順利的實現了AJax無重新整理省市聯動

 

問題:

但是發現在頁面提交的時候後台讀取不了DropDownList的值,而且提示出錯:

 

回傳或回調參數無效。在配置中使用 <pages enableEventValidation="true"/> 或在頁面中使用 <%@ Page EnableEventValidation="true" %> 啟用了事件驗證。出於安全目的,此功能驗證回傳或回調事件的參數是否來源於最初呈現這些事件的伺服器控制項。如果資料有效並且是預期的,則使用 ClientScriptManager.RegisterForEventValidation 方法來註冊回傳或回調資料以進行驗證。

 

在網上找了一下,發現很多人都遇到這種問題,有人列出了以下方法:

1、在頁面的<%@ Page Language="C#" AutoEventWireup="true" CodeFile="Default.aspx.cs" Inherits="_Default" %> 中添加 EnableEventValidation="false" 就可以了。
2、是Form嵌套,一個頁面只能有一個Form,仔細檢查代碼就可以解決。
3、如果頁面含有 DropDownList 或 ListBox這樣的控制項,可能以下原因造成:
3.1 在下拉式功能表中使用ajax,常見於省市聯動菜單,可能是由於在aspx頁面賦給了下拉式功能表初始Item值,在事件回傳時提示該錯誤,將下拉式功能表初始Item值刪除,在綁定事件中添加Item項。
3.2 原因是 DropDownList 控制項的ListItem 的Value 屬性 包含漢字.只要將Value 改為英文或數位就行了.最好在web.config中添加如下語句:
<globalization requestEncoding="utf-8" responseEncoding="utf-8" culture="zh-CN" uiCulture="zh-CN"/>因為 POSTBACK 如果不採用 UTF-8 編碼, JAVASCRIPT 會認為有問題。
只改 requestEncoding="utf-8" 就可以了,responseEncoding="utf-8" 不用
4、Register For Event Validation
其原理就是讓asp.net記錄這個postback value.
RegisterForEventValidation必須在render時調用.

但是試了以上的幾種方法都不可用

第一種方法加了EnableEventValidation="false"後,頁面不提示錯誤了,但是後台依然讀取不了DropDownList的資料

 

最後解決方案:

(把DropDownList改為用戶端Html控制項select,然後用Ajax儲存,肯定不會有錯誤,但是這裡表單有很多需要提交的資料,所以不考慮用用戶端Html控制項)

1、在頁面的<%@ Page Language="C#" AutoEventWireup="true" CodeFile="Default.aspx.cs" Inherits="_Default" %> 中添加 EnableEventValidation="false";

2、在頁面添加隱藏欄位<input type="hidden" id="inputCity" runat="server" />,然後用JS將DropDownList選擇後的值賦值給隱藏欄位,

這樣後台就可以通過 inputCity.Value 來讀取到隱藏欄位的值,也就是省市選擇的值了

 

 

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.