您的位置:首页 > Web前端 > JQuery

jQuery 中的 DOM 操作介绍

2009-09-05 21:49 495 查看
 0hi猿团提供了移动跨平台开发视频,包括html5,apicloud appcan,dcloud,具体请看http://www.9y.cm 

jQuery 中的 DOM 操作,佟刚讲得真不错!

1.内容过滤选择器的过滤规则主要体现在它所包含的子元素和文本内容上

例题:<input type="button" value="选择 含有文本 'di' 的 div 元素" id="btn1" />

        <input type="button" value="选择不包含子元素(或者文本元素) 的 div 空元素" id="btn2" />

        <input type="button" value="选择含有 class 为 mini 元素的 div 元素" id="btn3" />

        <input type="button" value="选择含有子元素(或者文本元素)的div元素" id="btn4" />

        <input type="button" value="选择 含有文本 'mi' 的直接 div 元素" id="btn5" />

答案:<script type="text/javascript" src="scripts/jquery-1.3.1.js"></script>

        <script type="text/javascript">

            $(document).ready(function(){

                function anmateIt(){

                    $("#mover").slideToggle("slow", anmateIt);

                }

   

                anmateIt();       

               

                $("#btn1").click(function(){

                    $("div:contains(di)").css("background", "#ffbbaa");

                });   

               

                $("#btn2").click(function(){

                    $("div:empty").css("background", "#ffbbaa");

                });   

               

                $("#btn3").click(function(){

                    $("div:has(.mini)").css("background", "#ffbbaa");

                });   

               

                $("#btn4").click(function(){

                    $("div:parent").css("background", "#ffbbaa");

                });   

               

                $("#btn5").click(function(){

                    $("div:contains(mi)").css("background", "#ffbbaa");

                });       

               

            });

功能:改变含有文本 ‘di’ 的 div 元素的背景色为 # bbffaa

改变不包含子元素(或者文本元素) 的 div 空元素的背景色为 # bbffaa

改变含有 class 为 mini 元素的 div 元素的背景色为 # bbffaa

改变含有子元素(或者文本元素)的div元素的背景色为 # bbffaa

2.可见性过滤选择器

可见性过滤选择器是根据元素的可见和不可见状态来选择相应的元素

可见选择器 :hidden 不仅包含样式属性 display 为 none 的元素, 也包含文本隐藏域 (<input  type=“hidden”>)和 visible:hidden 之类的元素

3.<input type="button" value="选取所有可见的  div 元素" id="btn1">

        <input type="button" value="选择所有不可见的 div 元素" id="btn2" />

        <input type="button" value="选择所有不可见的 input 元素" id="btn3" />

       

答案:$(document).ready(function(){

                function anmateIt(){

                    $("#mover").slideToggle("slow", anmateIt);

                }

   

                anmateIt();   

               

                $("#btn1").click(function(){

                    $("div:visible").css("background", "#bbffaa");

                });

               

                $("#btn2").click(function(){

                    $("div:hidden").show(1000).css("background", "#bbffaa");

                });

               

                $("#btn3").click(function(){

                    alert($("input:hidden").attr("value"));

                });

            });

功能:改变所有可见的div元素的背景色为 # bbffaa

选取所有不可见的元素, 利用 jQuery 中的 show() 方法将它们显示出来, 并设置其背景色为 # bbffaa

选取所有的文本隐藏域, 并打印它们的值

4.属性过滤选择器

属性过滤选择器的过滤规则是通过元素的属性来获取相应的元素

例题:<input type="button" value="选取含有 属性title 的div元素." id="btn1"/>

        <input type="button" value="选取 属性title值等于'test'的div元素." id="btn2"/>

        <input type="button" value="选取 属性title值不等于'test'的div元素(没有属性title的也将被选中)." id="btn3"/>

        <input type="button" value="选取 属性title值 以'te'开始 的div元素." id="btn4"/>

        <input type="button" value="选取 属性title值 以'est'结束 的div元素." id="btn5"/>

        <input type="button" value="选取 属性title值 含有'es'的div元素." id="btn6"/>

        <input type="button" value="组合属性选择器,首先选取有属性id的div元素,然后在结果中 选取属性title值 含有'es'的 div 元素." id="btn7"/>

       

答案:$(document).ready(function(){

                $("#btn1").click(function(){

                    $("div[title]").css("background", "#bbffaa");

                });

               

                $("#btn2").click(function(){

                    $("div[title=test]").css("background", "#bbffaa");

                });

               

                $("#btn3").click(function(){

                    $("div[title!=test]").css("background", "#bbffaa");

                });

               

                $("#btn4").click(function(){

                    $("div[title^=te]").css("background", "#bbffaa");

                });

               

                $("#btn5").click(function(){

                    $("div[title$=est]").css("background", "#bbffaa");

                });

               

                $("#btn6").click(function(){

                    $("div[title*=es]").css("background", "#bbffaa");

                });

               

                $("#btn7").click(function(){

                    $("div[id][title*=es]").css("background", "#bbffaa");

                });

            });

功能:选取下列元素,改变其背景色为 # bbffaa

含有属性title 的div元素.

属性title值等于"test"的div元素.

属性title值不等于"test"的div元素(没有属性title的也将被选中).

属性title值 以"te"开始 的div元素.

属性title值 以"est"结束 的div元素.

属性title值 含有"es"的div元素.

选取有属性id的div元素,然后在结果中选取属性title值含有“es”的 div 元素.

6.子元素过滤选择器

nth-child() 选择器详解如下:

(1) :nth-child(even/odd): 能选取每个父元素下的索引值为偶(奇)数的元素

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

(3):nth-child(3n): 能选取每个父元素下的索引值是 3 的倍数 的元素

(3):nth-child(3n + 1): 能选取每个父元素下的索引值是 3n + 1的元素

通过子元素可以完成一下:

选取下列元素,改变其背景色为 # bbffaa

每个class为one的div父元素下的第2个子元素.

每个class为one的div父元素下的第一个子元素

每个class为one的div父元素下的最后一个子元素

如果class为one的div父元素下的仅仅只有一个子元素,那么选中这个子元素

7.表单对象属性过滤选择器

表单对象属性过滤选择器示例

<h3>表单对象属性过滤选择器</h3>

         <button id="btn1">对表单内 可用input 赋值操作.</button>

           <button id="btn2">对表单内 不可用input 赋值操作.</button><br /><br />

         <button id="btn3">获取多选框选中的个数.</button>

         <button id="btn4">获取下拉框选中的内容.</button><br /><br />

答案:$(document).ready(function(){

                $("#btn1").click(function(){

                    $("input:enabled").attr("value", "我是可用的 input ^^");

                });

               

                $("#btn2").click(function(){

                    $("input:disabled").attr("value", "^^ 我是不可用的 input");

                });

               

                $("#btn3").click(function(){

                    alert($(":checkbox:checked").length);

                });

               

                $("#btn4").click(function(){

                    //each() 方法: jQuery 对象的方法, 可以对选定的 jQuery 对象(因为 jQuery 对象就是数组)进行遍历.

                    //参数是一个回调函数

                    $("select :selected").each(function(){

                        // this 是当前正在被遍历的那个 javascript 对象

                        alert($(this).text());

                    });

                });

功能:利用 jQuery 对象的 val() 方法改变表单内可用 <input> 元素的值

利用 jQuery 对象的 val() 方法改变表单内不可用 <input> 元素的值

利用 jQuery 对象的 length 属性获取多选框选中的个数

利用 jQuery 对象的 text() 方法获取下拉框选中的内容

8.jQuery 中的 DOM 操作

DOM(Document Object Model—文档对象模型):一种与浏览器, 平台, 语言无关的接口, 使用该接口可以轻松地访问页面中所有的标准组件

DOM 操作的分类:

DOM Core: DOM Core 并不专属于 JavaScript, 任何一种支持 DOM 的程序设计语言都可以使用它. 它的用途并非仅限于处理网页, 也可以用来处理任何一种是用标记语言编写出来的文档, 例如: XML

HTML DOM: 使用 JavaScript 和 DOM 为 HTML 文件编写脚本时, 有许多专属于 HTML-DOM 的属性

CSS-DOM:针对于 CSS 操作, 在 JavaScript 中, CSS-DOM 主要用于获取和设置 style 对象的各种属性

9.查找节点

查找节点:

查找属性节点: 通过 jQuery 选择器完成.

查找属性节点: 查找到所需要的元素之后, 可以调用 jQuery 对象的 attr() 方法来获取它的各种属性值

10.创建节点

创建节点: 使用 jQuery 的工厂函数 $(): $(html); 会根据传入的 html 标记字符串创建一个 DOM 对象, 并把这个 DOM 对象包装成一个 jQuery 对象返回.

注意:

动态创建的新元素节点不会被自动添加到文档中, 而是需要使用其他方法将其插入到文档中;

当创建单个元素时, 需注意闭合标签和使用标准的 XHTML 格式. 例如创建一个<p>元素, 可以使用 $(“<p/>”) 或 $(“<p></p>”), 但不能使用 $(“<p>”) 或 $(“<P>”)

创建文本节点就是在创建元素节点时直接把文本内容写出来; 创建属性节点也是在创建元素节点时一起创建

11.插入节点(1)

动态创建 HTML 元素并没有实际用处, 还需要将新创建的节点插入到文档中, 即成为文档中某个节点的子节点

以上方法不但能将新创建的 DOM 元素插入到文档中, 也能对原有的 DOM 元素进行移动.

12.删除节点

remove(): 从 DOM 中删除所有匹配的元素, 传入的参数用于根据 jQuery 表达式来筛选元素. 当某个节点用 remove() 方法删除后, 该节点所包含的所有后代节点将被同时删除. 这个方法的返回值是一个指向已被删除的节点的引用.

empty(): 清空节点 – 清空元素中的所有后代节点(不包含属性节点).

13.复制节点

clone(): 克隆匹配的 DOM 元素, 返回值为克隆后的副本. 但此时复制的新节点不具有任何行为.

clone(true): 复制元素的同时也复制元素中的的事件

14.替换节点

replaceWith(): 将所有匹配的元素都替换为指定的 HTML 或 DOM 元素

replaceAll(): 颠倒了的 replaceWith() 方法.

注意: 若在替换之前, 已经在元素上绑定了事件, 替换后原先绑定的事件会与原先的元素一起消失

15.包裹节点

wrap(): 将指定节点用其他标记包裹起来. 该方法对于需要在文档中插入额外的结构化标记非常有用, 而且不会破坏原始文档的语义.

wrapAll(): 将所有匹配的元素用一个元素来包裹. 而 wrap() 方法是将所有的元素进行单独包裹.

wrapInner(): 将每一个匹配的元素的子内容(包括文本节点)用其他结构化标记包裹起来.

16.属性操作

attr(): 获取属性和设置属性

当为该方法传递一个参数时, 即为某元素的获取指定属性

当为该方法传递两个参数时, 即为某元素设置指定属性的值

jQuery 中有很多方法都是一个函数实现获取和设置. 如: attr(), html(), text(), val(), height(), width(), css() 等.

removeAttr(): 删除指定元素的指定属性

19.样式操作

获取 class 和设置 class : class 是元素的一个属性, 所以获取 class 和设置 class 都可以使用 attr() 方法来完成.

追加样式: addClass()

移除样式: removeClass() --- 从匹配的元素中删除全部或指定的 class

切换样式: toggleClass()  --- 控制样式上的重复切换.如果类名存在则删除它, 如果类名不存在则添加它.

判断是否含有某个样式: hasClass() --- 判断元素中是否含有某个 class, 如果有, 则返回 true; 否则返回 false

20.设置和获取 HTML, 文本和值

读取和设置某个元素中的 HTML 内容: html() . 该方法可以用于 XHTML, 但不能用于 XML 文档

读取和设置某个元素中的文本内容: text(). 该方法既可以用于 XHTML 也可以用于 XML 文档.

读取和设置某个元素中的值: val() --- 该方法类似 JavaScript 中的 value 属性. 对于文本框, 下拉列表框, 单选框该方法可返回元素的值(多选框只能返回第一个值).如果为多选下拉列表框, 则返回一个包含所有选择值的数组

21.常用的遍历节点方法

取得匹配元素的所有子元素组成的集合: children(). 该方法只考虑子元素而不考虑任何后代元素.

取得匹配元素后面紧邻的同辈元素的集合(但集合中只有一个元素): next()

取得匹配元素前面紧邻的同辈元素的集合(但集合中只有一个元素): prev()

取得匹配元素前后所有的同辈元素: siblings()

22.CSS-DOM 操作

获取和设置元素的样式属性: css()

获取和设置元素透明度: opacity 属性

获取和设置元素高度, 宽度: height(), width(). 在设置值时, 若只传递数字, 则默认单位是 px. 如需要使用其他单位则需传递一个字符串, 例如 $(“p:first”).height(“2em”);

获取元素在当前视窗中的相对位移: offset(). 其返回对象包含了两个属性: top, left. 该方法只对可见元素有效

23.jQuery 中的事件 --  加载 DOM

在页面加载完毕后, 浏览器会通过 JavaScript 为 DOM 元素添加事件. 在常规的 JavaScript 代码中, 通常使用 window.onload 方法, 在 jQuery 中使用$(document).ready() 方法.

24.合成事件

hover(): 模拟光标悬停时间. 当光标移动到元素上时, 会触发指定的第一个函数, 当光标移出这个元素时, 会触发指定的第二个函数.

toggle(): 用于模拟鼠标连续单击事件. 第一次单击元素, 触发指定的第一个函数, 当再一次单击同一个元素时, 则触发指定的第二个函数, 如果有更多个函数, 则依次触发, 直到最后一个.

toggle() 的另一个作用: 切换元素的可见状态.

25.事件冒泡

事件会按照 DOM 层次结构像水泡一样不断向上只止顶端

解决: 在事件处理函数中返回 false, 会对事件停止冒泡. 还可以停止元素的默认行为.

26.事件对象的属性

事件对象: 当触发事件时, 事件对象就被创建了. 在程序中使用事件只需要为函数添加一个参数. 该事件对象只有事件处理函数才能访问到. 事件处理函数执行完毕后, 事件对象就被销毁了.

event.pageX, event.pageY: 获取到光标相对于页面的 x, y 坐标.

30.移除事件

移除某按钮上的所有  click 事件: $(“btn”).unbind(“click”)

移除某按钮上的所有事件: $(“btn”).unbind();

one(): 该方法可以为元素绑定处理函数. 当处理函数触发一次后, 立即被删除. 即在每个对象上, 事件处理函数只会被执行一次.

31.jQuery 中的动画: 隐藏和显示

hide(): 在 HTML 文档中, 为一个元素调用 hide() 方法会将该元素的 display 样式改为 none. 代码功能同 css(“display”, “none”);

show(): 将元素的 display 样式改为先前的显示状态.

以上两个方法在不带任何参数的情况下, 作用是立即隐藏或显示匹配的元素, 不会有任何动画. 可以通过制定速度参数使元素动起来.

以上两个方法会同时减少(增大)内容的高度, 宽度和不透明度.

fadeIn(), fadeOut(): 只改变元素的透明度. fadeOut() 会在指定的一段时间内降低元素的不透明度, 直到元素完全消失. fadeIn() 则相反.

slideDown(), slideUp(): 只会改变元素的高度. 如果一个元素的 display 属性为 none, 当调用 slideDown() 方法时, 这个元素将由上至下延伸显示. slideUp() 方法正好相反, 元素由下至上缩短隐藏.

35.在 eclipse 中安装 Aptana 插件

把下载好的插件里的内容(只保留features和plugins这两个文件夹)放在eclipse 的 aptana 文件夹中

在eclipse文件夹里新建一个links文件夹,里面再建一个aptana.link文件,内容为path=/aptana
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息