首页 > jquery通过attr获取属性值为什么都是undefind?

jquery通过attr获取属性值为什么都是undefind?


这里的jQuery和$是等效的,
为什么通过attr改变标签的display不起作用,
jQuery(this).next('ul').attr("display")得到的是undefind。

 jQuery(document).ready(function($){
    jQuery("#cataloguelist").children("ul li:first").children("ul").attr('dispaly','block');


    jQuery(".grayp").on('click',function(){
      var tr=jQuery(this).next('ul').attr("display");
      if(tr=="none"){
        jQuery(this).next('ul').attr("display","block")
      }
      else{
        jQuery(this).next('ul').attr("display","none");
      }
    });
  });

display 不是标签的style 属性么?


看你的意思是想取CSS属性,应该用 css() 而不是 attr


你是要通过JQuery来控制元素的显示和隐藏吗?attr是获取DOM的attribute,而display是属于样式中规则名,不属于attribute,所以会返回undefined

可以利用css()方法实现,给一个参考的Demo:Demo

HTML中,还需要区分attributeproperty:HTML中的attribute和property


用attr()应该是取到style属性

【热门文章】
【热门文章】