JS:Cannot set property 'display' of undefined问题

先贴上js代码

function judgeAll(){
			var cancel = document.getElementById("cancel");
			var judge = document.getElementsByClassName("judge");
			cancel.onclick = function(){
				if (judge.style.display=="") {
					judge.style.display = "block";
					cancel.value = "取消";
				}else{
					judge.style.display = "";
					cancel.value = "编辑";
				}
			}
		}

先获取按钮的id名和下拉框的class名,然后进行判定,如果下拉框judge被隐藏了,就display:block;如果下拉框judge没被隐藏,就display:none。很简单的想法,但是出错了。

错误信息
错误信息

 

 

 

"Cannot set property 'display' of undefined"

开始还以为我语法写错了,检查后发现没有,然后上网查了原因,才发现原因在class名judge这里。

"judge.style.display=='none';"

class类不能简单直接拿来判断,因为具有多个class,所以要加上数组才能判断。

改进代码如下:

function judgeAll(){
			var cancel = document.getElementById("cancel");
			var judge = document.getElementsByClassName("judge");
			cancel.onclick = function(){
				if (judge[0].style.display == '' ) {
					for(var i=0;i<judge.length;i++){
					 	judge[i].style.display = "block";
						cancel.value = "取消";
					}
				}else if(judge[0].style.display == 'block'){
					for(var i=0;i<judge.length;i++){
						judge[i].style.display = "";
						cancel.value = "编辑";
					}
				}
				
			}
		}

 

  • 9
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 6
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值