时间:2021-05-18
问题描述:
在IE8及以下版本时,点击label标签无法自动触发checkbox的click事件,导致无法产生希望的效果。
原HTML代码:
<div class="col-sm-2"> <label><input type="checkbox" id="chk_sqjc" value="申请检查" name="menu" class="cbr cbr-blue">申请检查</label> </div>$("input:checkbox[name='menu']").each(function (index, element) { $(this).click(function () { if ($(this).attr("checked") != undefined) { $(this).removeAttr("checked"); var menues = $("#selmenues").val(); var arrMenues = menues.split(','); if (arrMenues.length > 0) { arrMenues.forEach(function (val) { //console.log(element.value); if (element.value == val) { arrMenues.splice($.inArray(val, arrMenues), 1); } }); menues = ""; arrMenues.forEach(function (val) { menues += val + ','; }); menues = menues.substring(0, menues.length - 1) //console.log(menues); $("#selmenues").val(menues); //console.log($("#selmenues").val()); } } else { $(this).attr("checked", "checked"); var menues = $("#selmenues").val(); var arrMenues = menues.split(','); if (arrMenues.length > 0) { arrMenues.push($(this).val()); menues = ""; arrMenues.forEach(function (val) { menues += val + ','; }); menues = menues.substring(0, menues.length - 1) //console.log(menues); } else { menues += $(this).val() + ','; } $("#selmenues").val(menues); //console.log($("#selmenues").val()); } }) });根本原因:因为ie8不支持事件传递,当点击蓝色的框框时,触发了label的click事件而并没有触发其中checkbox标签的click事件。
解决方式:我们可以修改html代码,将label标签和checkbox标签通过id属性关联,同时给label加上name属性,将事件处理放在label标签上。
新HTML代码:
<div class="col-sm-2"> <label name="lbl_menu" id="sqjc"><input type="checkbox" id="chk_sqjc" value="申请检查" name="menu" class="cbr cbr-blue">申请检查</label></div>$("label[name='lbl_menu']").each(function (index, element) { $(this).click(function () { //console.log($('input#chk_' + this.id).attr("checked")); if ($('input#chk_' + this.id).attr("checked") != undefined) { $('input#chk_' + this.id).removeAttr("checked"); //$('input#chk_' + this.id).trigger("click"); $('div').filter('.cbr-replaced.cbr-blue').eq(index).removeClass('cbr-checked'); var menues = $("#selmenues").val(); var arrMenues = menues.split(','); if (arrMenues.length > 0) { arrMenues.forEach(function (val) { //console.log(element.value); if (element.value == val) { arrMenues.splice($.inArray(val, arrMenues), 1); } }); menues = ""; arrMenues.forEach(function (val) { menues += val + ','; }); menues = menues.substring(0, menues.length - 1) //console.log(menues); $("#selmenues").val(menues); //console.log($("#selmenues").val()); } } else { $('input#chk_' + this.id).attr("checked", "checked"); // console.log($('input#chk_' + this.id).attr("checked")); //$('input#chk_' + this.id).trigger("click"); // console.log($('.cbr-replaced.cbr-blue')[index]); $('div').filter('.cbr-replaced.cbr-blue').eq(index).addClass('cbr-checked'); var menues = $("#selmenues").val(); var arrMenues = menues.split(','); if (arrMenues.length > 0) { arrMenues.push($('input#chk_' + this.id).val()); menues = ""; arrMenues.forEach(function (val) { menues += val + ','; }); menues = menues.substring(0, menues.length - 1) //console.log(menues); } else { menues += $('input#chk_' + this.id).val() + ','; } $("#selmenues").val(menues); //console.log($("#selmenues").val()); } }) });最后加一下IE版本的判断代码就完美了。
完整JS代码
var DEFAULT_VERSION = 8.0; var ua = navigator.userAgent.toLowerCase(); var isIE = ua.indexOf("msie") > -1; var safariVersion; if (isIE) { safariVersion = ua.match(/msie ([\d.]+)/)[1]; } if (safariVersion <= DEFAULT_VERSION) { $("label[name='lbl_menu']").each(function (index, element) { $(this).click(function () { //console.log($('input#chk_' + this.id).attr("checked")); if ($('input#chk_' + this.id).attr("checked") != undefined) { $('input#chk_' + this.id).removeAttr("checked"); //$('input#chk_' + this.id).trigger("click"); $('div').filter('.cbr-replaced.cbr-blue').eq(index).removeClass('cbr-checked'); var menues = $("#selmenues").val(); var arrMenues = menues.split(','); if (arrMenues.length > 0) { arrMenues.forEach(function (val) { //console.log(element.value); if (element.value == val) { arrMenues.splice($.inArray(val, arrMenues), 1); } }); menues = ""; arrMenues.forEach(function (val) { menues += val + ','; }); menues = menues.substring(0, menues.length - 1) //console.log(menues); $("#selmenues").val(menues); //console.log($("#selmenues").val()); } } else { $('input#chk_' + this.id).attr("checked", "checked"); // console.log($('input#chk_' + this.id).attr("checked")); //$('input#chk_' + this.id).trigger("click"); // console.log($('.cbr-replaced.cbr-blue')[index]); $('div').filter('.cbr-replaced.cbr-blue').eq(index).addClass('cbr-checked'); var menues = $("#selmenues").val(); var arrMenues = menues.split(','); if (arrMenues.length > 0) { arrMenues.push($('input#chk_' + this.id).val()); menues = ""; arrMenues.forEach(function (val) { menues += val + ','; }); menues = menues.substring(0, menues.length - 1) //console.log(menues); } else { menues += $('input#chk_' + this.id).val() + ','; } $("#selmenues").val(menues); //console.log($("#selmenues").val()); } }) }); } else { $("input:checkbox[name='menu']").each(function (index, element) { $(this).click(function () { if ($(this).attr("checked") != undefined) { $(this).removeAttr("checked"); var menues = $("#selmenues").val(); var arrMenues = menues.split(','); if (arrMenues.length > 0) { arrMenues.forEach(function (val) { //console.log(element.value); if (element.value == val) { arrMenues.splice($.inArray(val, arrMenues), 1); } }); menues = ""; arrMenues.forEach(function (val) { menues += val + ','; }); menues = menues.substring(0, menues.length - 1) //console.log(menues); $("#selmenues").val(menues); //console.log($("#selmenues").val()); } } else { $(this).attr("checked", "checked"); var menues = $("#selmenues").val(); var arrMenues = menues.split(','); if (arrMenues.length > 0) { arrMenues.push($(this).val()); menues = ""; arrMenues.forEach(function (val) { menues += val + ','; }); menues = menues.substring(0, menues.length - 1) //console.log(menues); } else { menues += $(this).val() + ','; } $("#selmenues").val(menues); //console.log($("#selmenues").val()); } }) }); }总结
以上所述是小编给大家介绍的解决包含在label标签下的checkbox在ie8及以下版本点击事件无效果兼容的问题,希望对大家有所帮助,如果大家有任何疑问欢迎给我留言,小编会及时回复大家的!
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
下载了一个jQueryEasyUI1.3.4的demo,发现IE8以下版本的浏览器不好使,主要还有一些客户还在使用XP系统,IE8等浏览器,这样选择兼容版本
1.兼容ie8主要是事件兼容varEventUtil={on:function(elem,type,handler){if(elem.addEventListe
解决方法有两种:一种是CSS,使用background-size:cover实现图片的拉伸效果,但是IE8及以下版本不支持background-size,于是可
热门的tag非IE8莫属各浏览器厂商争相发布版本更新部分网页也存在与IE8的兼容性问题简单一行代码,让IE8自动调用IE7的渲染模式只需要在页面中加入如下HTT
rgba()是css3的新属性,所以IE8及以下浏览器不兼容,这怎么办呢?终于我找到了解决办法。解决办法我们先来解释以下rgbargba:rgba的含义,r代表