浅析 jQuery 功能

591 阅读3分钟

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设计思想》。