时间:2021-05-18
最近在项目中,遇到一个问题,测试全选/反选功能时,第一次对母框进行选中/非选中时,能同步子框的全选/反选状态,之后再点击母框,子框就没反应了。
原代码大致结构关键如下:
function selectAll(obj){ $('input[name="xxx[]"]').attr("checked",obj.checked);}<input type="checkbox" id="mother" name="mother" onclick="selectAll(this);"/>全选<input type="checkbox" id="son1" name="xxx[]" />子框<input type="checkbox" id="son2" name="xxx[]" />子框<input type="checkbox" id="son3" name="xxx[]" />子框<input type="checkbox" id="son4" name="xxx[]" />子框步骤一:尝试正面刚一波:
function selectAll(obj){ if(obj.checked) { $('input[name="xxx[]"]').attr("checked", true); } else { $('input[name="xxx[]"]').removeAttr("checked"); }}卒-----完全没有效果,弃之。
步骤二:快速上网搜索一番,发现这个问题比较常见,在遇到过这个问题的人里,我应该排在千里之外了。点开几个看了,基本都是说用prop替代attr便能解决,奈何如下:
然而项目上用的版本低于1.6并被告知最好不要更改版本,同弃之。
步骤三:无可奈何,JQuery弃之...尝试改用原生js写法,代码如下:
function selectAll(obj){ var xxx = document.getElementsByName("xxx[]"); if(obj.checked) { for(var i = 0;i < xxx.length;i++) { xxx[i].checked = true; } } else { for(var i = 0;i < xxx.length;i++) { xxx[i].checked = false; } }}测试一下,顺利解决。其实也算是个小问题,不过给了我一些启示,不能局限在一个框里,多换个角度思考问题,往往能更好地去解决问题。
以上这篇解决JQuery全选/反选第二次失效的问题就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
问题的来源用el-autocomplete远程获取数据时,点击输入框会触发第一次请求,然后输入搜索文字后会触发第二次请求,两次请求间隔较短,有时候会出现第二次请
上一篇讲到:第一次点击全选按钮input显示对勾,第二次则不显示,需要用prop来添加checked属性。 但是用prop会出现一个问题,对勾显示,而chec
jquery全选、全不选、反选效果的实现代码【推荐】首先:引入jqueryharan.info_jquery实例_全选全不选反选_select-all_unse
今天小编为大家带来的是“淘宝如何申请二次售后”这一问题的解答。淘宝如何申请二次售后?很多朋友对此非常纳闷。看到身边的朋友一个个可以在淘宝申请第二次售后,使得自己
淘宝影响二次销售定义是怎样的?淘宝影响二次销售举证如何操作?通俗点来说,淘宝影响二次销售定义是你损坏了产品本来的样子,会影响第二次出售,产品不是完整的或者产