1、jQuery 获取元素
jQuery的基本设计思想和主要用法,就是"选择某个网页元素,然后对其进行某种操作"。这是它区别于其他Javascript库的根本特点。
jQuery是一个不需要加new的构造函数。 使用jQuery的第一步,往往就是将一个选择表达式,放进构造函数jQuery(),然后得到被选中的元素。
window.$=window
——因此使用$
代为jQuery
。
选择表达式可以是CSS选择器:
$(document) //选择整个文档对象
$('#Id') //选择ID为Id的网页元素
$('div.myClass') // 选择class为myClass的div元素
$('input[name=first]') // 选择name属性等于first的input元素
也可以是jQuery特有的表达式:jQuery的扩展
$('a:first') //选择网页中第一个a元素
$('tr:odd') //选择表格的奇数行
$('#myForm :input') // 选择表单中的input元素
$('div:visible') //选择可见的div元素
$('div:gt(2)') // 选择所有index(索引值)大于2的元素(index从0开始计算)
$('div:animated') // 选择当前处于动画状态的div元素
2、jQuery 的链式操作
jQuery在最终选中网页元素以后,可以对它进行一系列操作,并且所有操作可以连接在一起,以链条的形式写出来。
它的原理在于每一步的jQuery操作,返回的都是一个jQuery对象,所以不同操作可以连在一起。jQuery还提供了.end()
方法,使得结果集可以后退一步。
$('div') //找到div元素
.find('h3') //选择其中的h3元素
.eq(2) //选择第3个h3元素
.html('Hello') //将它的内容改为Hello
.end() //退回到选中所有的h3元素的那一步
.eq(0) //选中第一个h3元素
.html('World'); //将它的内容改为World
3、元素的创建、复制和删除
(1)元素的创建
创建新元素的方法非常简单,只要把新元素直接传入jQuery的构造函数就行了:
$('<p>Hello</p>');
$('<li class="new">new list item</li>');
$('ul').append('<li>list item</li>');
//apend在每个匹配元素里面的末尾处插入参数内容
(2)元素的删除
.detach() //从DOM中去掉所有匹配的元素
.remove() //将匹配元素集合从DOM中删除。(注:同时移除元素上的事件及 jQuery 数据。)
.empty() //这个方法不仅移除子元素(和其他后代元素),同样移除元素里的文本
区别:
.remove()
和.detach()
可以删除元素本身,前者不保留被删除元素的事件,后者保留,有利于重新插入文档时使用。.empty()
删除子元素但是不删除元素本身,还会删除元素本身的文本,因为这些文本会被当做子节点删除。
(3)复制
.clone()
—— 深拷贝。
4、元素的插入
元素的插入分为:(1)插入现有元素内;(2)插入现有元素外。
(1)插入现有元素内:
.append()
和.appendTo()
——作为最后一个子元素插入。
两者实现同样的功能。主要的不同是语法——内容和目标的位置不同。
例如
<h2>Greetings</h2>
<div class="container">
<div class="inner">Hello</div>
<div class="inner">Goodbye</div>
</div>
使用:
$('.inner').append('<p>Test</p>')
$('<p>Test</p>').appendTo('.inner')
均得到:
<div class="inner">Hello<p>Test</p> </div>
<div class="inner">Goodbye<p>Test</p> </div>
.prepend()
和.prependTo()
——作为第一个子元素插入。同样二者之间实现的功能相同,语法不同。
$('.inner').prepend('<p>Test</p>');
$('<p>Test</p>').prependTo('.inner');
均得到
<div class="inner">
<p>Test</p>
Hello
</div>
(2)插入现有元素外
.insertAfter()
和.after()
两者实现同样的功能。主要的不同是语法——特别是(插入)内容和目标的位置。
例如
<div class="container">
<h2>Greetings</h2>
<div class="inner">Hello</div>
</div>
使用:
$('<p>Test</p>').insertAfter('.inner');
$('.inner').after('<p>Test</p>');
均得到:
<div class="inner">Hello</div>
<p>Test</p>
.before()
和.insertBefore()
同理:
$('.inner').before('<p>Test</p>');
$('<p>Test</p>').insertBefore('.inner');
均得到:
<p>Test</p>
<div class="inner">Hello</div>
5、获取和设置属性
常用方法概述:
.attr()
——获取第一个元素的属性值。.removeAttr()
——元素集合中的每个元素中移除一个属性。.val()
——获取元素集合中第一个元素的当前值,主要用于获取表单元素的值。.addClass()
——增加样式名,样式名多个用空格隔开(这个方法不会替换一个样式类名。它只是简单的添加一个样式类名到元素上)。.css()
——获取和设置第一个元素的CSS属性。.removeClass()
——多个样式名需用空格隔开。.toggleClass()
——如果在元素集合中的每个元素上存在该样式类就会被移除;如果某个元素没有就会加上这个样式类。.html()
——取出或设置html内容。.text()
——取出或设置text内容。.offset()
——返回元素相对于文档的坐标。.position()
——取得元素相对于父元素的偏移位置。
参考文档:jQuery 中文文档,阮一峰的《jQuery设计思想》。
常见问题FAQ
- 免费下载或者VIP会员专享资源能否直接商用?
- 本站所有资源版权均属于原作者所有,这里所提供资源均只能用于参考学习用,请勿直接商用。若由于商用引起版权纠纷,一切责任均由使用者承担。更多说明请参考 VIP介绍。
- 提示下载完但解压或打开不了?
- 找不到素材资源介绍文章里的示例图片?
- 模板不会安装或需要功能定制以及二次开发?
发表评论
还没有评论,快来抢沙发吧!