你不需要设置 CheckBox 的 ID 来做你想做的事情(改变背景颜色)。你的 CheckBox 应该是这样的(KeyID
如果你想显示它,我添加了作为文本值......或者如果你只想要复选框,你可以删除它):
<asp:CheckBox runat="server" ID="checkbox" Text='<%# Eval("KeyID") %>' AutoPostBack="false"></asp:CheckBox>
现在您的复选框将呈现如下内容:
<input id="MainContent_Grid_checkbox_0" type="checkbox" name="ctl00$MainContent$Grid$ctl02$checkbox" /><label for="MainContent_Grid_checkbox_0">Value of KeyID</label>
由于所有名称都以“checkbox”结尾,因此您可以对名称以“checkbox”结尾的那些元素的更改事件应用函数。您没有指定这是一个 JavaScript 问题,或者如果您使用的是 jQuery ......这个答案使用jQuery:
<script>
$('input[name$="checkbox"]').change(function () {
if ($(this).is(':checked')) {
$(this).parent().css('background-color', 'yellow');
}
else {
$(this).parent().css('background-color', 'white');
}
});
</script>
这将确定复选框是否被选中,如果是,它将设置其父级的背景颜色(<td>
它所在的,在 DataGrid 呈现的 HTML 内),具体取决于值。
同样,您可以转到下一个parent()
并突出显示整行。
资源:
jQuery 选择器
OnCheckedChanged - 您将在后面的代码中处理的事件,而不是在 JavaScript 中。