http://www.cnblogs.com/best/p/5748515.html

调试:

seo优化培训,网络推广培训,网络营销培训,SEM培训,网络优化,在线营销培训

从上面的调试信息中可以看到foo是一个长度为1的集合,集合中下标为0的元素就是1个DOM元素(0:p#foo),上DOM示例中的foo对象完全一样;可以看出foo是一个长度为1的集合,集合中下标为0的元素就是1个DOM元素(0:p#foo),上DOM示例中的foo对象完全一样;可以看出foo是对DOM元素foo的封装,使用功能更加强大,从隐式原型__proto__中的内容就可以看到,中间提供了大量的方法,事件与属性,简化操作。

2.3、DOM转换成jQuery对象

要使用jQuery中的方法与属性就需要把一个JavaScript中的DOM对象转换成jQuery对象。

转换方法一:

使用工厂方法jQuery(DOM对象),如jQuery(document.getElementById("foo")),seo优化培训,网络推广培训,网络营销培训,SEM培训,网络优化,在线营销培训seo优化培训,网络推广培训,网络营销培训,SEM培训,网络优化,在线营销培训seo优化培训,网络推广培训,网络营销培训,SEM培训,网络优化,在线营销培训seo优化培训,网络推广培训,网络营销培训,SEM培训,网络优化,在线营销培训seo优化培训,网络推广培训,网络营销培训,SEM培训,网络优化,在线营销培训seo优化培训,网络推广培训,网络营销培训,SEM培训,网络优化,在线营销培训是jQuery方法的简写形式,也可以写成(document.getElementById("foo"))

转换方法二:

简化形式jQuery(选择器),如jQuery("#foo"),也可以写成$("#foo")

示例如下:

seo优化培训,网络推广培训,网络营销培训,SEM培训,网络优化,在线营销培训

<!DOCTYPE html><html>
    <head>
        <meta charset="UTF-8">
        <title>DOM转换成jQuery对象</title>
    </head>
    <body>
        <h2>DOM转换成jQuery对象</h2>
        <p id="foo">Foo</p>
        <p id="bar">Bar</p>
        <script type="text/javascript" src="js/jQuery/jquery.min.js" ></script>
        <script type="text/javascript">
        //方法一
        //在文档中获得id为foo的DOM对象
        var foo=document.getElementById("foo");        //将DOM对象转换成jQuery对象
        var $foo1=jQuery(foo);        var $foo2=$(foo);        //调用jQuery对象中的方法        $foo1.html("Foo jQuery");
        $foo2.css("color","red");        
        //方法二
        //获得文档中id为bar的DOM对象,将DOM包装成一个jQuery对象,调用jQuery方法html修改元素HTML        jQuery("#bar").html("Bar jQuery");        //为id为bar的元素设置样式,将前景色修改为蓝色        $("#bar").css("color","blue");        </script>
    </body></html>

seo优化培训,网络推广培训,网络营销培训,SEM培训,网络优化,在线营销培训

运行结果:

seo优化培训,网络推广培训,网络营销培训,SEM培训,网络优化,在线营销培训

2.4、jQuery对象转换成DOM对象

DOM对象是jQuery对象的组成部分,jQuery对象是对DOM对象的包装升级,每一个jQuery对象都是一个集合,是一个包装集,每个包装集中可以包含0到N个DOM元素。将jQuery对象转换成DOM对象方法如下

方法一:

jQuery对象[下标]

方法二:

jQuery对象.get(下标)

示例:

seo优化培训,网络推广培训,网络营销培训,SEM培训,网络优化,在线营销培训

<!DOCTYPE html><html>
    <head>
        <meta charset="UTF-8">
        <title>jQuery对象转换成DOM对象</title>
    </head>
    <body>
        <h2>jQuery对象转换成DOM对象</h2>
        <p id="foo">Foo</p>
        <p id="bar">Bar</p>
        <script type="text/javascript" src="js/jQuery/jquery.min.js" ></script>
        <script type="text/javascript">
        //方法一
        var $foo=$("#foo");        //从jQuery对象中获得下标为0的DOM元素,并调用DOM属性        $foo[0].innerHTML="foo DOM";        
        //方法二
        var $p=$("p");        //从jQuery对象中获得下标为1的DOM元素,并调用DOM属性        $p.get(1).innerHTML="bar DOM";        </script>
    </body></html>

seo优化培训,网络推广培训,网络营销培训,SEM培训,网络优化,在线营销培训

运行结果:

seo优化培训,网络推广培训,网络营销培训,SEM培训,网络优化,在线营销培训

2.5、DOM对象与jQuery对象区别

  1. DOM对象只能调用DOM方法、属性与事件;

  2. jQuery对象只能调用jQuery方法、属性与事件;

  3. 可以将DOM转换成jQuery对象,也可以将jQuery转换成DOM对象;

  4. $只是jQuery的别名形式;

  5. 每一个jQuery对象都是一个DOM对象的集合

三、常用选择器

通过jQuery中的选择器实际上取得的是HTML中的DOM元素。在jQuery中使用CSS匹配(CSS like)来进行元素指定,比其他JavaScript库都简单,这也正是jQuery在网页设计人员中大受欢迎的理由了。

在其核心,jQuery重点放在从HTML页面里获取元素并对其进行操作。如果你熟悉CSS,就会很清楚选择器的威力,通过元素的特性或元素在文档中的位置去描述元素组。有了jQuery,就能够利用现有知识去发挥选择器的威力,在很大程度上简化JavaScript代码。CSS中可以使用的选择器基本都可以用到jQuery中,反之不然。

3.1. 选择器和包装集

为了使设计和内容分离而把CSS引入Web技术的时候,需要以某种方式从外部样式表中引用页面元素组。开发出来的方法就是通过使用选择器—基于元素的属性或元素在HTML文档中的位置,简明地表现元素。

例如,选择器:p a

引用所有嵌套于<p>元素之内的超链接(<a>元素)组。jQuery利用同样的选择器,不仅支持目前CSS中使用的常见选择器,还支持尚未被大多数浏览器完全实现的更强大的选择器。收集一组元素,可以使用如下简单的语法:

$(selector) 或者 jQuery(selector)

也许刚开始你会觉得$()符号有点奇怪,但大部分jQuery用户很快就喜欢上它的简洁。例如,为了获取嵌套在<p>元素内的一组超链接,我们使用如下语句:

$("p a")

$( )函数返回特别的JavaScript对象,它包含着与选择器相匹配的DOM元素的数组。该对象拥有大量预定义的有用方法,能够作用于该组元素。

用编程的话来说,这种构造称为包装器(wrapper),因为它用扩展功能来对匹配的元素进行包装。我们使用术语jQuery包装器或者包装集(wrapped set),来指能够在其上用jQuery定义的方法去操作的、匹配元素的集合。

假定我们想选择带有CSS类notLongForThisWorld的所有<div>元素。jQuery语句如下所示:

$("notLongForThisWorld");

3.2.   基本选择器

基本选择器是jQuery中最常用的选择器,也是最简单的选择器,它通过元素id、class和标签名等来查找DOM元素。在网页中,每个id名称只能使用一次,class允许重复使用。

选择器

描述

返回

示例

#id

根据给定的id匹配一个元素

单个元素

$("#test")选取id为test的元素

.class

根据给定的类名匹配元素

集合元素

$(".test")选取所有class为test的元素

element

根据给定的元素名称匹配元素

集合元素

$("p")选取所有的<p>元素

selector1,

selector2,

selector3...

将每一个选择器匹配到的元素合并后一起返回

集合元素

$("div,span,p.cls")选取所有<div>,<span>和拥有class为cls的<p>标签的一组元素

*

匹配所有元素

集合元素

$("*")选取所有的元素

 

可以使用这些基本选择器来完成绝大多数的工作,下面我们对这些选择器一一进行讲解。

3.2.1、通过id获取元素

在CSS中经常使用id来控制元素,在jQuery中获取元素时,也使用同样方法。与CSS一样,在id前面加上#号。

语法:$("#id")

可以控制指定id的HTML元素,在HTML中有id不可重复的规定,因此可以控制文档内部惟一的元素。如果定义了多个同名的id元素,则只有最初出现的同名id有效。在JavaScript中使用document对象的getElemnetById(id)方法来获取元素,在jQuery中则更为简化。同时通过jQuery获得id对应的元素后可以调用jQuery中的相应方法对该元素进行操作,具体代码如下所示:

seo优化培训,网络推广培训,网络营销培训,SEM培训,网络优化,在线营销培训

<script type="text/javascript" src="js/jquery-1.11.3.js"></script><div id="notMe"><p>id="notMe"</p></div><div id="myDiv">id="myDiv"</div><script>
     $("#myDiv").css("border","3px solid red");</script>

seo优化培训,网络推广培训,网络营销培训,SEM培训,网络优化,在线营销培训

3.2.2、通过类名获取元素

在网页当中,使用class属性引用样式表中的类样式,因为类样式的可重用,所以多个元素可以引用同一个样式。在jQuery中,可以获取同一类名的多个HTML元素,编写方式同CSS,即在类名的前面加上点号。

语法:$(".className")

本例通过类名来获取元素,因为使用同一个类样式的元素可能有多个,所以通过类名来获取元素返回的将是一个数组对象,即jQuery中的包装集,然后对此包装集中的元素进行相关操作。示例代码如下所示:

seo优化培训,网络推广培训,网络营销培训,SEM培训,网络优化,在线营销培训

  <div class="myclass">div class="notMe"</div>
  <div class="myclass otherclass">div class="myClass"</div>
  <span class="myclass otherclass">span class="myClass"</span>
  <script>
     $(".myclass.otherclass").css("border","13px solid red");  </script>

seo优化培训,网络推广培训,网络营销培训,SEM培训,网络优化,在线营销培训

3.2.3、通过标签名获取元素

在CSS中我们通常使用标签名来为这一类标签定义样式,在jQuery中也可以用同样方法来获取标签元素。

如果使用普通JavaScript,则必须用document对象的getElementsByTagName(tagName)方法来进行元素的抓取。而jQuery方法与CSS相同,指定需要操作的标签名即可操控所有的标签。

语法:$("tagName")

示例代码如下所示:

seo优化培训,网络推广培训,网络营销培训,SEM培训,网络优化,在线营销培训

  <div>DIV1</div>
  <div>DIV2</div>
  <span>SPAN</span>
  <script>
     $("div").css("border","9px solid red");  </script>

seo优化培训,网络推广培训,网络营销培训,SEM培训,网络优化,在线营销培训

四、350行jQuery常用脚本

4.1、常用选择器

seo优化培训,网络推广培训,网络营销培训,SEM培训,网络优化,在线营销培训

$('#div1')   //id为div1的节点,如<div id='div1'></div> $('span')   //所有的span结点,一个包装集$('p span')   //p标签下的所有span节点,后代节点$('p>span')   //p标签下的所有span子节点,子代节点$('.red')  //使用样式red的节点,如<span class="red"></span>$('*')  //所有节点$("div,span,p.cls")  //选取所有<div>,<span>和拥有class为cls的<p>标签的一组元素

seo优化培训,网络推广培训,网络营销培训,SEM培训,网络优化,在线营销培训

4.2、基本筛选器

seo优化培训,网络推广培训,网络营销培训,SEM培训,网络优化,在线营销培训

$('span:first')    //第一个节点$('span:last')     //最后一个节点$("td:even")     //索引为偶数的节点,从 0 开始$("td:odd")      //索引为奇数的节点,从 0 开始 $("td:eq(1)")    //给定索引值的节点$("td:gt(0)")    //大于给定索引值的节点$("td:lt(2)")    //小于给定索引值的节点$(":focus")      //当前获取焦点的节点$(":animated")   //正在执行动画效果的节点

seo优化培训,网络推广培训,网络营销培训,SEM培训,网络优化,在线营销培训

4.3、内容选择器

$("div:contains('hello')")    //包含hello文本的节点$("td:empty")    //不包含子节点或者文本的空节点$("div:has(p)")  //含有选择器所匹配的节点$("td:parent")   //含有子节点或者文本的节点

4.4、表单选择器

seo优化培训,网络推广培训,网络营销培训,SEM培训,网络优化,在线营销培训

$("input:checked") //所有选中的节点$("select option:selected") //select中所有选中的option节点$(":input") //匹配所有 input, textarea, select 和 button 节点$(":text") //所有的单行文本框$(":password") //所有密码框$(":radio") //所有单选按钮$(":checkbox") //所有复选框$(":submit") //所有提交按钮$(":reset") //所有重置按钮$(":button") //所有button按钮$(":file") //所有文件域

seo优化培训,网络推广培训,网络营销培训,SEM培训,网络优化,在线营销培训

4.5、筛选与查找

seo优化培训,网络推广培训,网络营销培训,SEM培训,网络优化,在线营销培训

$("p").eq(0) //当前操作中第N个jQuery对象,类似索引$('li').first() //第一个节点$('li').last() //最后一个节点$(this).hasClass("node") //节点是否含有某个特定的类,返回布尔值$('li').has('ul') //包含特定后代的节点$("div").children() //div中的每个子节点,第一层$("div").find("span") //查找div下的所有span节点$("p").next()    //紧邻p节点后的一个同辈节点$("p").nextAll() //p节点之后所有的同辈节点$("#node").nextUntil("#node2") //id为"#node"节点之后到id为'#node2'之间所有的同辈节点,掐头去尾$("p").prev() //紧邻p节点前的一个同辈节点$("p").prevAll() //p节点之前所有的同辈节点$("#node").prevUntil("#node2") //id为"#node"节点之前到id为'#node2'之间所有的同辈节点,掐头去尾$("p").parent() //每个p节点的父节点$("p").parents() //每个p节点的所有祖先节点,body,html$("#node").parentsUntil("#node2") //id为"#node"节点到id为'#node2'之间所有的父级节点,掐头去尾$("div").siblings() //所有的同辈节点,不包括自己

seo优化培训,网络推广培训,网络营销培训,SEM培训,网络优化,在线营销培训

4.6、属性操作

seo优化培训,网络推广培训,网络营销培训,SEM培训,网络优化,在线营销培训

$("img").attr("src");        //返回文档中所有图像的src属性值$("img").attr("src","node.jpg"); //设置所有图像的src属性$("img").removeAttr("src");    //将文档中图像的src属性删除$("input[type='checkbox']").prop("checked", true); //选中复选框$("input[type='checkbox']").prop("checked", false); //不选中复选框$("img").removeProp("src");    //删除img的src属性

seo优化培训,网络推广培训,网络营销培训,SEM培训,网络优化,在线营销培训

4.7、样式操作

$("p").addClass("selected");   //为p节点加上 'selected' 类$("p").removeClass("selected"); //从p节点中删除 'selected' 类$("p").toggleClass("selected"); //如果存在就删除,否则就添加HTML代码/文本/值

4.8、内容操作

seo优化培训,网络推广培训,网络营销培训,SEM培训,网络优化,在线营销培训

$('p').html();            //返回p节点的html内容$("p").html("Hello <b>hello</b>!"); //设置p节点的html内容$('p').text();            //返回p节点的文本内容$("p").text("hello");        //设置p节点的文本内容$("input").val();          //获取文本框中的值$("input").val("hello");      //设置文本框中的内容

seo优化培训,网络推广培训,网络营销培训,SEM培训,网络优化,在线营销培训

4.9、CSS操作

$("p").css("color"); //访问查看p节点的color属性$("p").css("color","red"); //设置p节点的color属性为red$("p").css({ "color": "red", "background": "yellow" }); //设置p节点的color为red,background属性为yellow(设置多个属性要用{}字典形式)

4.10、定位与偏移

seo优化培训,网络推广培训,网络营销培训,SEM培训,网络优化,在线营销培训

$('p').offset() //节点在当前视口的相对偏移,对象 {top: 5, left: 9}$('p').offset().top
$('p').offset().left
$("p").position() //节点相对父节点的偏移,对可见节点有效,Object {top: 5, left: 8}$(window).scrollTop() //获取滚轮滑的高度$(window).scrollLeft() //获取滚轮滑的宽度$(window).scrollTop('25') //设置滚轮滑的高度为25

seo优化培训,网络推广培训,网络营销培训,SEM培训,网络优化,在线营销培训

4.11、尺寸

seo优化培训,网络推广培训,网络营销培训,SEM培训,网络优化,在线营销培训

$("p").height(); //获取p节点的高度$("p").width(); //获取p节点的宽度$("p:first").innerHeight() //获取第一个匹配节点内部区域高度(包括补白、不包括边框)$("p:first").innerWidth() //获取第一个匹配节点内部区域宽度(包括补白、不包括边框)$("p:first").outerHeight() //匹配节点外部高度(默认包括补白和边框)$("p:first").outerWidth() //匹配节点外部宽度(默认包括补白和边框)$("p:first").outerHeight(true) //为true时包括边距

seo优化培训,网络推广培训,网络营销培训,SEM培训,网络优化,在线营销培训

4.12、DOM内部插入

$("p").append("<b>hello</b>"); //每个p节点内后面追加内容$("p").appendTo("div");     //p节点追加到div内后$("p").prepend("<b>Hello</b>"); //每个p节点内前面追加内容$("p").prependTo("div");   //p节点追加到div内前

4.13、DOM外部插入

$("p").after("<b>hello</b>"); //每个p节点同级之后插入内容$("p").before("<b>hello</b>"); //在每个p节点同级之前插入内容$("p").insertAfter("#node"); //所有p节点插入到id为node节点的后面$("p").insertBefore("#node"); //所有p节点插入到id为node节点的前面

4.14、DOM替换

$("p").replaceWith("<b>Paragraph. </b>"); //将所有匹配的节点替换成指定的HTML或DOM节点$("<b>Paragraph. </b>").replaceAll("p"); //用匹配的节点替换掉所有 selector匹配到的节点

4.15、DOM删除

$("p").empty(); //删除匹配的节点集合中所有的子节点,不包括本身$("p").remove(); //删除所有匹配的节点,包括本身$("p").detach(); //删除所有匹配的节点(和remove()不同的是:所有绑定的事件、附加的数据会保留下来)

4.16、DOM复制

$("p").clone()   //克隆节点并选中克隆的副本$("p").clone(true) //布尔值指事件处理函数是否会被复制

4.17、DOM加载完成事件

seo优化培训,网络推广培训,网络营销培训,SEM培训,网络优化,在线营销培训

$(document).ready(function(){
    您的代码...
});//缩写$(function($) {
   您的代码...
});

seo优化培训,网络推广培训,网络营销培训,SEM培训,网络优化,在线营销培训

4.18、绑定事件

seo优化培训,网络推广培训,网络营销培训,SEM培训,网络优化,在线营销培训

//bind 为每个匹配节点绑定事件处理函数,绑定多个用{}。$("p").bind("click", function(){
    alert( $(this).text() );
});
$('#div1').bind({    "mouseover":function () {
         $('#div1').parent().removeClass("hide");
    },"mouseout":function () {
         $('#div1').parent().addClass("hide");
    }
});