求修改JS:gridview中某行中第二列checkbox控制第三列checkboxlist是否可用

beckhon 2011-11-04 11:21:13
刚学js的新手求助:
场景描述:gridview中有三列,第一列分类编号,第二列分类名称(checkbox),第三列子分类(checkboxList)
目的:点击某一行的checkbox,它对应的checkboxList的disabled跟着改变
现在的问题:我自己的代码 运行后 如果在某一行的checkbox上连点三下之后 就能达到要求,要不就是乱的
求代码,谢各位大神


<asp:GridView ID="gvWorkFlowImport" Width="100%" runat="server"
AutoGenerateColumns="False"
CssClass="gridview" onrowdatabound="gvWorkFlowImport_RowDataBound">
<Columns>
<asp:BoundField DataField="TypeId" HeaderText="分类编号" Visible="true" />
<asp:TemplateField HeaderText="分类名称">
<ItemTemplate>
<asp:CheckBox ID="chkWorkFlowType" Text='<%# DataBinder.Eval(Container.DataItem,"TypeName") %>' onclick='chkChanged()' runat="server" />
</ItemTemplate>
<ItemStyle HorizontalAlign="Center" />
</asp:TemplateField>
<asp:TemplateField HeaderText="工作流版本">
<ItemTemplate>
<asp:CheckBoxList ID="chkVerSionList" RepeatDirection="Horizontal" runat="server" />
</ItemTemplate>
<ItemStyle HorizontalAlign="Left" />
</asp:TemplateField>
</Columns>
</asp:GridView>


<script type="text/javascript">
function chkChanged() {
var table = document.getElementById("<%=gvWorkFlowImport.ClientID %>");
var chk;
for (var i = 1; i < table.rows.length; i++)
{
chk=table.rows[i].cells[1].getElementsByTagName("input");
if (typeof chk != "undefined " && chk != null)
{
var isChecked=chk[0].checked;
var chklist =table.rows[i].cells[2].getElementsByTagName("input");
for(var j=0;j<chklist.length;j++)
{
if(chklist[j].type=="checkbox")
{
chklist[j].disabled=!isChecked;
}
}
}
}
}
</script>
...全文
63 1 打赏 收藏 转发到动态 举报
写回复
用AI写文章
1 条回复
切换为时间正序
请发表友善的回复…
发表回复
beckhon 2011-11-04
  • 打赏
  • 举报
回复
顶上去再吃饭,各位进来的大哥大姐叔叔伯伯 各路大牛门,多停留几秒钟,帮个忙看看呗,小弟这厢谢谢了

62,254

社区成员

发帖
与我相关
我的任务
社区描述
.NET技术交流专区
javascript云原生 企业社区
社区管理员
  • ASP.NET
  • .Net开发者社区
  • R小R
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

.NET 社区是一个围绕开源 .NET 的开放、热情、创新、包容的技术社区。社区致力于为广大 .NET 爱好者提供一个良好的知识共享、协同互助的 .NET 技术交流环境。我们尊重不同意见,支持健康理性的辩论和互动,反对歧视和攻击。

希望和大家一起共同营造一个活跃、友好的社区氛围。

试试用AI创作助手写篇文章吧