不知道大家有沒有遇到這樣的情況?
在用jquery獲取下拉列表ddl的值時返回的為字符串‘null',而不是空值,結果導致獲取的參數不對;
即使在後台判斷了其非空,但還是導致了錯誤(比如拼湊SQL時將null拼進去了)。
下面我們來分析下:
第一種情況:
代碼如下:
<select id="ddlType">
<option value="">請選擇</option>
<option value="1">安徽省</option>
……
</select>
第二種情況:
代碼如下:
<select id="ddlType"></select>
或者
<asp:DropDownList ID="ddlType" runat="server"></asp:DropDownList>
我們在程序中這樣取值:
$("#ddlType").val()
針對第一種情況,如果我們沒有做選擇,那麼它返回的是空值“”,但不是字符串“null”;
而第二種情況,ddl中本來就沒有可選擇的項,前台沒有寫死或者後台沒有綁定,再去取它的值的話就會返回字符串“null”。
解決辦法:目前沒有找到比較好的解決辦法,只能在後台判斷時添加判斷( !="null"),顯然,這不是很好的辦法。
網上還有朋友提供的方法是修改jquery的源文件,將val函數的實現中的最後一句 this.value = val; 改成 this.value = val || "";
如果大家有什麼好的辦法,還望慷慨分享下!!!