先贴一段代码,这是正常情况:
<script type="text/javascript">
$(function () {
var tableHTML = new Array();
for (var i = 0; i < 5; i++) {
var chk = '<input οnchange="alert('+i+')" id="chk' + i + '" type="checkbox" /><label for="chk' + i + '">' + i + '</label>';
tableHTML.push(chk);
}
$("#divTables").html(tableHTML.join(''));
});
function c() {
$("input[type='checkbox']").each(function (i, t) {
$(t).click();
});
}
</script>
html:
<div id="divTables"></div>
<input type="button" οnclick="c();" />
这段代码的意思非常明确和简单,就是当点了这个按钮的时候,遍历页面中的checkbox并且调用它的click方法,然后来触发它自身的onchange事件
但是
我今天遇到的问题却始终达不到这个效果,非常的奇怪,最后也没有找到解决办法和问题出在哪里都不知道,
所以我就自己在下面写一onchange对应的函数 ,自己调用了一下,也达到了想要的效果
代码大同小异。如下:
var tables = getTables();
var tableHTML = new Array();
tables.each(function (i, t) {
var chk = '<input οnchange="tableCheck(this)" id="chk' + t.Name + '" type="checkbox" tableName="' + t.Name + '" simpleName="' + t.SimpleName + '" tableShowName="' + t.ShowName + '" /><label for="chk' + t.Name + '">' + t.ShowName + '</label>';
tableHTML.push(chk);
});
$("#divTables").html(tableHTML.join(''));
//选中的报表中的表
function checkRTables(rtbs) {
$(rtbs).each(function (i, t) {
var tname = t.split('-')[0];
var tsimpleName = t.split('-')[1];
$("#chk" + tname).attr("checked", "checked");
tableCheck($("#chk" + tname)[0]);//通过 这种方法来调用了那个onchange对应的方法
});
}