首頁 >web前端 >js教程 >jQuery 选择器、DOM操作、事件、动画

jQuery 选择器、DOM操作、事件、动画

PHP中文网
PHP中文网原創
2017-04-01 15:18:31948瀏覽

jquery的东西也算不少,记下来有助于以后参考。这样也挺方便。

Jquery选择器

$(document).ready(function(){})
$(function(){})

如果获取的对象jQuery对象,那么在变量前面加上$,例如:var $variable=jQuery对象

选择器

1, 判断页面是否存在某元素:if($(“#tt”).length>0){} 或者if($(“#tt”)[0]){};

2, 基本选择器

$(“#test”) 选择idtest的元素

$(“.test”)选择classtest的所有元素

$(“p”)选择所有的e388a4556c0f65e1904146cc1a846bee标签

$(“*”)选择页面上的所有元素

$(“span ,#two”)选择页面上所有的45a2772a6b6107b401db3c9b82c049c2标签和idtwo的元素

3, 层次选择器

$(“p span”)表示选取p中的所有的span元素

$(“parent>children”)选取parent下所有children的子元素

$(‘.one+span')选取classone的下一个span元素

$(‘.one~p')选取classone的后面的所有的p兄弟元素

$(‘.one+span')等价于$(“.one”).next(“span”)

$(‘one~p')等价于$(“.one”).nextAll(“p”)

$(“.one”).siblings(“p”) 选取classone的所有的兄弟元素p,无论前后

4, 过滤选择器

1基本的过滤器

$(“p:first”)选取所有p元素中第一个p元素

$(“p:last”)选取所有p元素最后一个p元素

$(“input:not(.myClass)”)选取class不是myClassinput元素

$(“input:even”)选取索引是偶数的input元素

$(“input:odd”)选取索引时奇数的input元素

$(“input:eq(1)”)选取索引等于1input元素 

$(“input:gt(1)”)选取索引大于1input元素(大于1不包括1

$(“input:lt(1)”)选取索引小于1input元素 (小于1不包括1

$(“:header”)选取网页中所有的h1h2……

$(“p:animated”)选取正在执行动画p元素

2内容过滤器

$(“p:contains(‘')”)选取含有文字“我”的p元素

$(“p:empty”)选取不包含子元素(包含文本元素)的p空元素

$(“p:has(p)”)选取含有p元素的p元素

$(“p:parent”)选取拥有子元素(包含文本元素)的p元素

3可见性过滤选择器

$(“:hidden”)选取所有不可见的元素。包括b36110a7fe5a79730b35a3506f95a3b4,6f943d4c784aa7acf613167b36fd38d7949ab30bebc0876d788c24b8c95c515a等元素。如果只想选取d5fd7aea971a85678ba271703566ebfd元素,可以使用$(“input:hidden”)

$(“p:visible”)选取所有可见的e388a4556c0f65e1904146cc1a846bee元素

 4属性过滤选择器

$(“p[id]”)选取拥有属性id的元素

$(“p[title=test]”)选取属性titletestp元素

$(“p[title!=test]”)选取属性title不是testp元素(没有属性titlep也会被选取)

$(“p[title^=test]”)选取属性titletest开始的p元素

$(“p[title$=test]”)选取属性titletest结束的p元素

$(“p[title*=test]”)选取属性title包含testp元素

$(“p[id][title$='test']”)选取拥有属性id,并且属性titletest结束的p元素

5子元素过滤选择器

:eq(index)只匹配一个元素,而:nth-child将为每一个父元素匹配子元素,并且:nth-child(index)index是从1开始的,而:eq(index)是从0算起的

:first只返回单个元素,而:first-child选择符将为每个父元素匹配第一个子元素。

例如$(“ul li:first-child”)选取每个ul中第一个li元素

:last只返回单个元素,而:last-child选择符将为每个父元素匹配最后一个子元素

$(“ul li:only-child”)ul中选取是唯一子元素的li元素

:nth-child()选择器是很常用的子元素过滤选择器,详细功能如下:

1.:nth-child(even)能选取每个父元素下的索引值是偶数的元素

2. :nth-child(odd)能选取每个父元素下的索引值的奇数的元素

3.:nth-child(2)能选取每个父元素下索引值等于2的元素

4.nth-child(3n)能选取每个父元素下的索引值是3的倍数的元素(n0开始)

5.nth-child(3n+1)能选取每个父元素下的索引值是(3n+1)的元素(n0开始)

6表单对象属性过滤选择器

$(“#form1 :enabled”)选取idform1的表单内的所有可用元素

$(“#form2 :disabled”)选取id为“form2”的表单内的所有不可用元素

$(“input:checked”)选取所有被选中的input元素

$(“select :selected”.text())选取所有被选中的选项元素

5.表单选择器

$(“:input”)选取所有inputtextareaselectbutton元素

$(“:text”)选取所有的单行文本框

$(“:password”)选取所有的密码框

$(“:radio”)选取所有的单选框

$(“:checkbox”)选取所有的复选框

$(“:submit”)选取所有的提交按钮

$(“:image”)选取所有的图像按钮

$(“:reset”)选取所有的重置按钮

$(“:button”)选取所有的按钮

$(“:file”)选取所有的上传

$(“:hidden”)选取所有不可见元素

Dom操作

Dom core(核心)、HTML-DOMCSS-DOM

1.       插入节点的方法

append()

$(“p”).append(“a4b561c25d9afb9ac8dc4d70affff4190d36329ec37a2cc24d42c7229b69747a”)

e388a4556c0f65e1904146cc1a846beetest a4b561c25d9afb9ac8dc4d70affff4190d36329ec37a2cc24d42c7229b69747a94b3e26ee717c64999d7867364b1b4a3

appendTo()

$(“a4b561c25d9afb9ac8dc4d70affff4190d36329ec37a2cc24d42c7229b69747a”).appendTo(“p”)

e388a4556c0f65e1904146cc1a846beetest a4b561c25d9afb9ac8dc4d70affff4190d36329ec37a2cc24d42c7229b69747a94b3e26ee717c64999d7867364b1b4a3

prepend()

$(“p”). prepend ( “a4b561c25d9afb9ac8dc4d70affff4190d36329ec37a2cc24d42c7229b69747a”)

e388a4556c0f65e1904146cc1a846beea4b561c25d9afb9ac8dc4d70affff4190d36329ec37a2cc24d42c7229b69747atest 94b3e26ee717c64999d7867364b1b4a3

prependTo()

$(“p”). prependTo ( “a4b561c25d9afb9ac8dc4d70affff4190d36329ec37a2cc24d42c7229b69747a”)

e388a4556c0f65e1904146cc1a846beea4b561c25d9afb9ac8dc4d70affff4190d36329ec37a2cc24d42c7229b69747atest 94b3e26ee717c64999d7867364b1b4a3

After()

$(“p”). after ( “a4b561c25d9afb9ac8dc4d70affff4190d36329ec37a2cc24d42c7229b69747a”)

e388a4556c0f65e1904146cc1a846beetest 94b3e26ee717c64999d7867364b1b4a3a4b561c25d9afb9ac8dc4d70affff4190d36329ec37a2cc24d42c7229b69747a

insertAfter()

$( “a4b561c25d9afb9ac8dc4d70affff4190d36329ec37a2cc24d42c7229b69747a”). insertAfter (“p”)

e388a4556c0f65e1904146cc1a846beetest 94b3e26ee717c64999d7867364b1b4a3a4b561c25d9afb9ac8dc4d70affff4190d36329ec37a2cc24d42c7229b69747a

Before()

$(“p”). before ( “a4b561c25d9afb9ac8dc4d70affff4190d36329ec37a2cc24d42c7229b69747a”)

a4b561c25d9afb9ac8dc4d70affff4190d36329ec37a2cc24d42c7229b69747ae388a4556c0f65e1904146cc1a846beetest 94b3e26ee717c64999d7867364b1b4a3

insertBefore()

$( “a4b561c25d9afb9ac8dc4d70affff4190d36329ec37a2cc24d42c7229b69747a”). insertBefore (“p”)

a4b561c25d9afb9ac8dc4d70affff4190d36329ec37a2cc24d42c7229b69747ae388a4556c0f65e1904146cc1a846beetest 94b3e26ee717c64999d7867364b1b4a3

2.       删除节点

Remove()方法    empty()清空节点

3.       复制节点

Clone()           $(this).clone(true).appendTo(“body”)

复制元素的同时复制元素中所绑定的事件

4.       替换节点

replaceWith():$(“p”).replaceWith(“<a>test</a>”);
replaceAll():$(“<a>test</a>”). replaceAll (“p”);

5.       包裹节点

Wrap()

$(“strong”).wrap(“a4b561c25d9afb9ac8dc4d70affff4190d36329ec37a2cc24d42c7229b69747a”);a4b561c25d9afb9ac8dc4d70affff4198e99a69fbe029cd4e2b854e244eab143ssss128dba7a3a77be0113eb0bea6ea0a5d00d36329ec37a2cc24d42c7229b69747a

wrapAll()

$(“strong”). wrapAll (“a4b561c25d9afb9ac8dc4d70affff4190d36329ec37a2cc24d42c7229b69747a”);a4b561c25d9afb9ac8dc4d70affff4198e99a69fbe029cd4e2b854e244eab143ssss128dba7a3a77be0113eb0bea6ea0a5d0

8e99a69fbe029cd4e2b854e244eab143ssss128dba7a3a77be0113eb0bea6ea0a5d00d36329ec37a2cc24d42c7229b69747a

wrapInner()

$(“strong”).wrapInner (a4b561c25d9afb9ac8dc4d70affff4190d36329ec37a2cc24d42c7229b69747a”);8e99a69fbe029cd4e2b854e244eab143a4b561c25d9afb9ac8dc4d70affff419ssss0d36329ec37a2cc24d42c7229b69747aac614297babda07451c2ac7bdedd5452

 

6.       属性操作

Attr();    设置多个$(“p”).attr({“title”:”dd”,”name”:”myp”})

removeAttr()移除属性

7.       样式操作

获取和设置样式

Attr()

追加样式

addClass()

移除样式

removeClass()    removeClass(“one two”)

切换样式

toggle()主要控制行为上的重复切换

toggleClass()样式上的重复切换

判断是否含有某个样式

hasClass()等价于is(“.one”)

8.设置和获取html、文本和值

html()

读取或者设置某个元素中的HTML内容

text()

读取或者设置某个元素中文本内容

val()

设置和获取元素的值defaultValue初始值

9.遍历节点

Children()

取得匹配元素的子元素的集合,只考虑子元素不考虑后代元素

Next()

取得匹配元素后面紧邻的同辈元素

Prev()

取得匹配元素前面紧邻的同辈元素

Siblings()

取得匹配元素前后所有的同辈元素

Closest()

取得最近的匹配元素

还有很多遍历方法:find(),filter(),nextAll(),prevAll(),parent(),parents()

 

CSS-DOM操作

获取样式

$(“.one”).css(“color”)

设置样式

$(“.one”).css(“color”,”red”)

$(“.one”).css({“opacity”:”0.5”,”background-color”:”blue”})

Height()

$(“.one”).height(),设置:$(“.one”).height(“20px”)

Width()

$(“.one”).width(),设置:$(“.one”).width(“200px”)

Offset()

获取元素在当前视窗的相对偏移,包括topleft

Position()

获取元素相对于最近的一个position样式属性设置为relative或者absolute的祖父节点的相对偏移,它返回的对象也包括两个属性,即topleft

ScrollTop()

获取和设置元素的滚动条距顶端的距离

ScrollLeft()

获取和设置元素的滚动条距左侧的距离

事件和动画

事件

(1)       绑定事件

bind(type[,data],fn);

参数:type:事件类型,也可以自定义名称

      data:作为event.data属性值传递给事件对象的额外数据对象

      fn:用来绑定的处理函数

绑定多个事件类型

Ex:$(“p”).bind(“mouseover mouseout”,function(){
$(this).toggleClass(“over”);
})

(2)       合成事件

Hover(enter,leave);

用于模拟光标悬停事件。当光标移动到元素上时,会触发指定的第一个函数(enter);当光标移除这个元素时,会触发指定的第二个函数(leave

toggle(fn1,fn2,….fnN);

用户模拟鼠标连续单击事件。第一次单击元素,触发指定的第一个函数;当在次单击同一个元素时,则触发指定的第二个函数(fn2);如果有更多的函数,则依次触发,知道最后一个。

(3)       冒泡事件

假设网页上有2个元素,其中一个元素嵌套在另一个元素里,并且都被绑定了click事件,同时body元素也绑定了click事件,当点击最里面元素的事件时,同时其它事件也会触发。从内向外

停止事件冒泡的方法:

stopPropagation()
Ex:$(‘span&#39;).bind(“click”,function(event){
Var txt=$().html()+”<p>内层span元素被单击</p>”;
$(‘#msg&#39;).html(txt);
Event.stopPropagation(); 停止事件冒泡
})


停止表单默认提交:event.preventDefault()==return false;

(4)       移除事件

Unbind([type][,data]);

Type:事件类型

Data:将要移除的函数

(5)       触发一次函数

One(type,[data],fn);

事件触发后立即解除

动画

Show()

Slow:600毫秒、normal400毫秒、fast200毫秒

Hide()

Fadeln()

在指定的一段时间内降低元素的不透明度,直到元素完全消失

fadeout()

和上相反

slideUp()

与下相反

slideDown()

元素将由上之下延伸显示

自定义动画animate

语法结构:animate(params,speed,callback);

参数说明如下:

1. Params:一个包含样式属性及值的映射,比如{property1:“value1”,property2:”value2”,….}

2. Speed:速度参数,可选。

Callback:在动画完成时执行的函数,可选

     就暂时先添加这点吧,以后再慢慢完善吧!

 以上就是jQuery 选择器、DOM操作、事件、动画的内容,更多相关内容请关注PHP中文网(www.php.cn)!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn