jquery关于选择器数组的问题
<scripttype="text/javascript"src="jQ/jquery-1.4.2.min.js"></script><scriptlanguage="j...
<script type="text/javascript" src="jQ/jquery-1.4.2.min.js"></script>
<script language="javascript">
<style>
li,span{
list-style:none;
display:none;}
.on{display:block;
}
</style>
</head>
<body>
<div id="a">
<li >2</li>
<li>3</li>
<li>4</li>
<li>5</li>
<li>6</li>
</div>
<div id="b">
<span>1</span>
<span>2</span>
<span>3</span>
<span>4</span>
</div>
</body>
1.在JS里写
$(function(){$("#b>span")[0].className="on";})可以执行没有问题,可是$("#b>span")换成$("#a>li")就不可以了,为什么?
2.$(function(){$("#b>span")[0].className="on";})换成$(function(){$("#b>span")[0].arrt("class","on");})也不行为什么?
3.$("#b>span")和$("#a>li")到底返回的是数组还是什么?不用遍历函数和eq(),该如何操作?
谢谢
4.className,addClass,arrt("calss",""),这三个到底怎么用啊,怎么区别啊?
真心求教! 展开
<script language="javascript">
<style>
li,span{
list-style:none;
display:none;}
.on{display:block;
}
</style>
</head>
<body>
<div id="a">
<li >2</li>
<li>3</li>
<li>4</li>
<li>5</li>
<li>6</li>
</div>
<div id="b">
<span>1</span>
<span>2</span>
<span>3</span>
<span>4</span>
</div>
</body>
1.在JS里写
$(function(){$("#b>span")[0].className="on";})可以执行没有问题,可是$("#b>span")换成$("#a>li")就不可以了,为什么?
2.$(function(){$("#b>span")[0].className="on";})换成$(function(){$("#b>span")[0].arrt("class","on");})也不行为什么?
3.$("#b>span")和$("#a>li")到底返回的是数组还是什么?不用遍历函数和eq(),该如何操作?
谢谢
4.className,addClass,arrt("calss",""),这三个到底怎么用啊,怎么区别啊?
真心求教! 展开
3个回答
展开全部
$("#a>li")不行我估计是因为你书写不规范所致,li的父级元素应该是ul,你换成ul试试。
$(function(){$("#b>span")[0].arrt("class","on");})有两个错误,首先是attr而不是arrt,然后$("#b>span")[0]获取的javascript对象,js对象是不能使用jquery方法的。
这两返回的都是数组,一般要么是遍历要么就是取具体的某一个元素,真想出来还有什么其他的用法或操作。
className是js中属性,addClass是jquery来给某个对象添加class的,不会删除或修改原来的class,attr("class","")是将class属性修改为指定值。
更多追问追答
追问
谢谢,关于第三个问题,我是想知道在jQ中如何进行像普通的数组a[i]这样的操作,而不是each遍历,用变量i控制值?
追答
这个好像在jquery里面不能这样操作,因为遍历他都封装到each里面了,要么你把他转成js对象,在for循环遍历,但是这样我感觉没那个必要,别人给你铺了条直路,你为什么非得走弯路。
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询
广告 您可能关注的内容 |