kbv*_*hnu 0 html asp.net jquery internet-explorer
我正在使用parentNode.nextElementSibling.value访问复选框的兄弟;它将返回值并在Firefox中正常工作.但在IE中它表示对象为空并且说
Microsoft JScript运行时错误:'parentNode.nextElementSibling.value'为null或不是对象
我的功能如下
function chkEnergy() {
var inputs = $('.check input');
var count = 0;var ok = 1;
for (var i = 0; i < inputs.length; i++) {
//alert(inputs[i].attr('checked'));
if (inputs[i].checked == true) {
var ch = inputs[i];
var qty=ch.parentNode.nextElementSibling.value;
if (qty == "0") {
ok = 0;
showStatus(true, "Please specify the Quantity");
return false;
}
else {
ok = 1;
continue;
}
}
}
if(ok==1)
return true
else
return false;
}
Run Code Online (Sandbox Code Playgroud)
我使用这种方式将dataList放在复选框和文本框中
<asp:DataList ID="dlstEnergyItems" runat="server" RepeatColumns="4" RepeatDirection="Horizontal" Width="100%">
<ItemTemplate>
<asp:CheckBox ID="cbEnergyItems" runat="server" CssClass="check" />
<input type="text" id="txtQty" style="width:25px" class="hide textbox numbers_only" value="0" runat="server" />
<asp:HiddenField ID="HdfEnergy" runat="server" />
<asp:HiddenField ID="HdfEnergyCID" runat="server" />
</ItemTemplate>
</asp:DataList>
Run Code Online (Sandbox Code Playgroud)
Renederd HTML
<table cellspacing="0" border="0" style="width: 100%;
border-collapse: collapse;"
id="ctl00_ContentPlaceHolder1_dlstEnergyItems">
<tbody><tr>
<td>
<span class="check"><input type="checkbox" name="ctl00$ContentPlaceHolder1$dlstEnergyItems$ctl00$cbEnergyItems" id="ctl00_ContentPlaceHolder1_dlstEnergyItems_ctl00_cbEnergyItems"><label for="ctl00_ContentPlaceHolder1_dlstEnergyItems_ctl00_cbEnergyItems">
Energy-1</label></span>
<input type="text" value="0" class="textbox numbers_only" style="width: 25px;" id="ctl00_ContentPlaceHolder1_dlstEnergyItems_ctl00_txtQty" name="ctl00$ContentPlaceHolder1$dlstEnergyItems$ctl00$txtQty">
<input type="hidden" value="1" id="ctl00_ContentPlaceHolder1_dlstEnergyItems_ctl00_HdfEnergy" name="ctl00$ContentPlaceHolder1$dlstEnergyItems$ctl00$HdfEnergy">
<input type="hidden"
id="ctl00_ContentPlaceHolder1_dlstEnergyItems_ctl00_HdfEnergyCID" name="ctl00$ContentPlaceHolder1$dlstEnergyItems$ctl00$HdfEnergyCID">
</td></tr></tbody></table>
Run Code Online (Sandbox Code Playgroud)
@ jsalonen有权原因(缺乏IE支持),但有一个解决方案在这里......如果你包括jQuery的,使用它:)这里是你的函数,它会工作的跨浏览器的一个短版:
function chkEnergy() {
var fails = $('.check:has(input:checked)').next("[value=0]").length;
if (fails > 0) showStatus(true, "Please specify the Quantity");
return fails === 0;
}
Run Code Online (Sandbox Code Playgroud)
在此我们使用.next()以获取输入字段,并使用属性等于选择在同一时间得到只有拥有这些领域value的0(失败的数量检查).如果.length我们找到的元素超过了0那么我们会有一些失败...显示警报并返回false.
| 归档时间: |
|
| 查看次数: |
636 次 |
| 最近记录: |