jQuery操作DOM详解

一、DOM操作的分类

1.DOM Core简介:

DOMCore并不属于javaScript,任何一种支持DOM的程序设计语言都可以使用它。它的用途并非仅限于处理网页,也可以用来处理任何一种使用标记语言编写出来的文档,例如XML。
javaScript中的getElementById(),getElementsByTagName(),getAttribute()和setAttribute()等方法,这些都是DOM core的组成部分。
使用DOMCore来获取表单对象的方法:document.getElementsByTagName("form");
获取某元素的src属性的方法:element.getAttribute("src");

2.HTML-DOM简介

在使用JavaScript和DOM为HTML文件编写脚本时,有许多专属于HTML-DOM的属性。HTML-DOM的出现甚至比DOM core还要早,它提供了一些更简明的记号来描述各种

HTML元素的属性。

获取表单对象的方法:document.forms

获取某原是的src属性的方法:element.src

3.CSS-DOM简介

CSS-DOM是针对CSS的操作。

如:设置某元素style对象字体颜色的方法:element.style.color = "red"

二、jQuery中的DOM操作

1.查找元素节点

<p title="选择你最喜欢的水果.">你最喜欢的水果?p>
    <ul>
        <li title='苹果'>苹果li>
        <li title='橘子'>橘子li>
        <li title='菠萝'>菠萝li>
    ul>

    //获取<ul>里第二个<li>节点的文本内容并且打印出来
    alert($('ul li:eq(1)').text());

2.查找属性节点

通过attr(attributeName)方法来获取它的各种属性

    //获取p元素的title属性值
    alert($('p').attr('title'));

3.2.2创建节点

1.创建元素节点 $(html)
例:要创建两个li元素节点,并且要把它们作为ul元素节点的子节点添加到DOM节点数上。

解题步骤:

创建两个li新元素
将这两个新元素插入文档中
$(html)方法会根据传入的HTML标记字符串,创建一个DOM对象,并将这个DOM对象包装成一个jQuery对象后返回:

    var $li_1 =  $("
  • "
    );//创建第一个li元素 var $li_2 = $("
  • "
    );//创建第二个li元素 可以使用jQuery的append()等方法将两个新元素插入文档中。 $("ul").append($li_1).append($li_2); //添加到ul节点中,使之能在网页中显示

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

    2.创建文本节点
    var $li_2 =  $("
  • ">香蕉
  • "
    ); $("ul").append($li_2);

    3.2.3插入节点

    3.2.3.1append() 向每个匹配的元素内部追加内容
    <p>我想说p>
        $("p").append("<b>你好b>");
        结果
        <p>我想说<b>你好b>p>
    3.2.3.2appendTo() 将所有匹配的元素追加到指定的元素中。与appdend方法正好反方向
    <p>我想说p>
        $("<b>你好b>").appendTo("p");
        结果
        <p>我想说<b>你好b>p>
    3.2.3.3prepend() 向每个匹配的元素内部前置内容
    <p>我想说p>
        $("p").prepend("<b>你好b>");
        结果
        <p><b>你好b>我想说p>
    3.2.3.4prependTo()
    <p>我想说p>
        $("<b>你好b>").prependTo("p");
        结果
        <p><b>你好b>我想说p>
    3.2.3.5after()添加到匹配元素标签结束符后面
    $("p").after("<b>你好b>");
        结果
        <p>我想说p><b>你好b>
    3.2.3.6insertAfter()用法与after方法反方向
    3.2.3.7before()在每个匹配的元素之前插入内容
        $("p").before("<b>你好b>");
        结果
        <b>你好b><p>我想说p>
    3.2.3.8insertBefore()

    这些插入节点的方法不仅能将新创建的DOM元素插入到文档中,也能对原有的DOM元素进行移动。

    3.2.3.9对原有的DOM元素进行移动
        var $one_li = $("ul li:eq(1)");
        var $two_li = $("ul li:eq(2)");
    
        $two_li.insertBefore($one_li);//移动节点

    3.2.4删除节点

    1.remove()方法

    从DOM中删除所有匹配的元素,传入的参数用于根据jQuery表达式来筛选元素。
    删除后,所有后代节点将同时删除。这个方法的返回值是一个指向已被删除的节点的引用,因此可以在以后再使用这些元素。

    另外remove方法也可以通过传递参数来选择性的删除元素,
    
    $("ul li").remove("li[title!=菠萝]");
    2.empty()方法:

    empty方法并不是删除节点,而是清空节点,它能清空元素中的所有后代节点。

    3.2.5复制节点

    复制节点也是常用的DOM操作之一,

    商品拖动功能就是用的复制节点,将用户选择的商品所处的节点元素复制一次,并2将其跟随鼠标移动,从而达到以下购物效果
    
    clone()
        clone(true) 绑定事件也被传递
    
        $("ul li").click(function(){
        $(this).clone().appendTo("ul");//复制当前单击的节点,并将它追加到
      元素中 })

    3.2.6替换节点

    1.replaceWith():将所有匹配的元素都替换成指定的HTML或者DOM元素。
    $("p").replaceWith("你最不喜欢的水果是?");
    2.replaceAll():与replaceWith使用反过来
    $("你最不喜欢的水果是?").replaceAll("p");
    3.注意事项

    如果在替换之前,已经为元素绑定事件,替换后原来绑定的事件将会与被替换的元素一起消失,需要在新元素上重新绑定事件

    3.2.7包裹节点

    如果要将某个节点用其他标记包裹起来,jQuery提供了相应的方法,即wrap().

    1.wrap()方法
    $("strong").wrap("");//用b标签把strong元素包裹起来
    2.wrapInner()方法
    $("strong").wrapInner("");//用b标签把strong元素里面的内容包裹起来

    3.2.8属性操作

    在jQuery中,用attr()方法来获取和设置元素属性,removeAttr()方法来删除元素属性

    1.1.获取和设置属性attr()
    var $para = $("p");//获取p节点
        var p_txt = $para.attr("title")//获取p元素节点属性title
    
        $("p").attr("title","your title");//设置单个的属性值
    
        设置多个属性值
    
        $("p").attr({"title":"your title","name":"test"});
    
        jQuery中还有很多方法都是同一个函数实现获取和设置的。html(),text(),height(),width(),val()css()等
    2.删除属性removeAttr()
    $("p").removeAttr("title");//删除p元素的属性title

    3.2.9样式操作

    1.获取样式和设置样式
    获取样式 var p_class = $("p").attr("class"); //获取p元素的class
        设置样式 $("p").attr("class","high");//设置p元素的classhigh
    2.追加样式:addClass(“样式名称”);
    <p class="abc">p>
    
        $("p").addClass("wen");
    
        <p class="abc  wen">p>
    
        两个样式合并, wen样式中与abc样式中有同样的属性时,以后wen为准。
    3.移除样式removeClass()
    $("p").removeClass("high");
    
        $("p").removeClass("high").removeClass("another");
    
        $("p").removeClass("high  another"); 移除classhighanother样式
    
        $("p").removeClass(); //移除p元素所有class属性
    
    4.切换样式toggleClass()

    样式切换toggleClass(“another”):如果another类名存在则删除它,不存在则添加它。

    $toggleBtn.toggle(function(){//显示元素
        代码①
    },function(){
        //隐藏元素
        代码②
    })
        toggle()方法此处作用是交替执行代码①和代码②两个函数。
    5.判断是否含有某个样式hasClass(“another”)
    hasClass("another"):存在class为another则返回true,不存在则返回false

    3.2.10 设置和获取HTML、文本和值

    1.html()方法:
    <p title="选择你最喜欢的水果."><strong>你最喜欢的水果?strong>p>
    
        alert($("p").html());//获取p节点中的内容,包括html元素。弹出的内容为<strong>你最喜欢的水果?strong>
    
        $("p").html("<strong>你最最最喜欢的水果是?strong>");//设置p节点中的内容,原来内容被覆盖,
    
        注意:该方法可以用于XHTML文档,但不能用于XML文档
    2.text()方法
    与javaScript的innerText属性类似。用来读取或者设置某个元素中的文本内容
    
        alert($("p").text());//获取p节点中的内容,包括html元素。弹出的内容为你最喜欢的水果?
    
        $("p").text("你最最最喜欢的水果是?");//设置p节点中的内容,原来内容被覆盖,标签也会当做文本输出
    
        注意:javascript中的innerText属性并不能再Firefox浏览器下运行,而jquery的text()方法支持所有的浏览器
    
        text()方法对HTML文档和XML文档都有效
    3.val()方法

    此方法类似于javaScript中的value属性,可以用来设置和获取元素的值。

    <script type="text/javascript">
    $(function(){//网页加载时
        $('#address').focus(function(){//获得地址焦点时
        var txt_value = $(this).val();//获取地址文本框的值
        if(txt_value=="请输入邮箱地址"){
            $(this).val("");
        }
        })
    
        $('#address').blur(function(){//失去地址焦点时
        var txt_value = $(this).val();//获取地址文本框的值
        if(txt_value==""){
            $(this).val("请输入邮箱地址");
        }
        })
    
        //对密码框进行操作
        $('#password').focus(function(){//获得密码焦点时
        var txt_value = $(this).val();//获取密码文本框的值
        if(txt_value==this.defaultValue){//使用defaultValue属性
            $(this).val("");
        }
        })
    
        $('#password').blur(function(){//失去密码焦点时
        var txt_value = $(this).val();//获取密码文本框的值
        if(txt_value==""){
            $(this).val(this.defaultValue);
        }
    
        })
    
    })
    
    
            script>
    
      <body>
        <input type="text" id="address" value="请输入邮箱地址" />
        <input type="text" id="password" value="请输入邮箱密码"/>
        <input type="button" value="登录"/>
      body>
    this指向当前的文本框,this.defaultValue就是当前文本框的默认值

    通过上面的例子可以发现val()方法,不仅能设置元素的值,也能获取元素的值。
    另外,val()方法还有另外一个用处,就是它能使select、checkbox和radio相应的选项被选中,在表单操作中会经常用到。

    下面构建一个网页演示val()方法该功能

            
        

    type="checkbox" value="check1" />多选1 type="checkbox" value="check2" />多选2 type="checkbox" value="check3" />多选3 type="checkbox" value="check4" />多选4
    type="radio" value="radio1" />单选1 type="radio" value="radio2" />单选2 type="radio" value="radio3" />单选3 如果要使第1个下拉框的第2项被选中 $("#single").val("选择2号"); $("#single option:eq(1)").attr("selected",true);//与上面一样 如果要使下拉列表的第2项和地3项被选中 $("#multipe").val(["选择2号","选择3号"]); $(":checkbox").val(["check2","check3"]);//选择多选按钮的check2,和check3 $(":radio").val(["radio2"]);//选择单选按钮中radio2被选中 $("[value=radio2]:radio").attr("checked",true);//与上面一样 在jQUery中,val方法是从最后一个选项往前读取,如果选项的value或者text中任意一项符合就会被选中。 例如 无论使用val("选择1号")还是val("选择2号"),都会选中后面一个。

    3.2.11遍历节点

    1.children()方法
    该方法用于取得匹配元素的子元素集合
    该方法只考虑子元素而不考虑任何后代元素
    
    2.next()方法
    该方法用于取得匹配元素后面紧邻的同辈元素。
    
    3.prev()方法
    用于取得匹配元素前面紧邻的同辈元素
    
    4.sublings()方法
    用于取得匹配元素前后所有的同辈元素
    
    5.closest()
    它用来取得最近的匹配元素。首先检查当前元素是否匹配,如果匹配则直接返回元素本身。如果不匹配则向上查找父元素,逐级向上直到找到匹配选择器的元素。如果什么都找不到则返回一个空的jquery对象。
    

    6.给目标元素的最近的li元素添加颜色

    $(document).bind("click",function(e){
        $(e.target).closest("li").css("color","red");
    })

    3.2.12CSS-DOM操作

    无论是外部,还是内联都能够通过css()方法提取、设置属性值
    css();

    
        $("p").css("color","red");//设置p元素的样式颜色为红色
        $("p").css({"fontSize":"30px","backgroundColor":"#888888"});
    
        注意:如果值是数字,将会被自动转化为像素值。
        在css方法中,如果属性中带有-符号,将-符号后面的首字母大写,总之,最好是加上引号。
    
        对透明度的设置,可以直接使用opacity属性。
    
         $("p").css("opacity","0.5");//将p元素设置为半透明
    
        如果需要获取某个元素的height属性,可以通过如下代码实现
    
        $(element).css("height");
        $("p").height();
    
        height()方法也能用来设置元素的高度,如果传递的值是一个数字,则默认单位为px,如果要用其他单位,则必须传递一个字符串。
    
        注意:在jquery1.2版本以后的height()方法可以用来获取window和docment的高度。
        两者的区别是:css()方法获取的高度值与样式的设置有关,可能会得到auto,也可能得到10px之类的字符串;而height()方法获取的高度值则是元素在页面中的实
    
    际高度,与样式的设置无关,并且不带单位
    
        width()方法,与height()方法类似。
    1.offset()方法

    它的作用是获取元素在当前视窗的相对偏移,其中返回的对象包含两个属性,即top和left,它只对可见元素有效。

    获取p元素的偏移量,jQuery
        var offset = $("p").offset();
        var left = offset.left;//获取左偏移
        var top = offset.top; //获取上偏移
    2.position()方法

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

    3.scrollTop()方法和scrollLeft()方法
    分别是获取元素的滚动条距顶端的距离和距左侧的距离。例如使用下面的代码获取p元素的滚动条距离。
    
    var $p = $("p");
        var scrollTop = $p.scrollTop();//获取元素的滚动条距顶端的距离
        var scrollLeft = $p.scrollLeft();//获取元素的滚动条距左侧的距离
        另外,为这两个方法指定一个参数,控制元素的滚动条滚动到指定位置。

    三、案例研究—某网站的超链接和图片提示效果

    1.超链接提示效果

    浏览器已经自带了超链接提示,只需在超链接中加入title属性就可以了。
    然后这个提示效果的响应速度是非常缓慢的,考虑到良好的人机交互,需要的是当鼠标移动到超链接的那一瞬间就出现提示。这时就需要移除标签中的title提示

    效果,自己动手做一个类似功能的提示。

    首先在空白页面上,添加两个普通超链接和两个带有class的超链接。
    
    <p>
            <a href="#" class="tooltip" title="这是我的超链接提示1.">提示1.a>
        p>
        <p>
            <a href="#" class="tooltip" title="这是我的超链接提示2.">提示2.a>
        p>
        <p>
            <a href="#"  title="这是自带的超链接提示1.">提示1.a>
        p>
        <p>
            <a href="#"  title="这是自带的超链接提示2.">提示2.a>
        p>

    然后为class为tooltip的超链接添加mouseover和mouseout事件,jQuery代码如下:

    $("a.tooltip").mouseover(function(){
        //显示title
    }).mouseout(function(){
        //隐藏title
    });

    实现这个效果的具体思路如下:
    (1)当鼠标滑入超链接
    ①创建一个div元素,div元素的内容为title属性的值
    ②将创建的元素追加到文档中
    ③为它设置x坐标和y坐标,使它显示在鼠标位置的旁边。
    (2)当鼠标滑出超链接时,移除div元素

    $(function(){//网页加载时运行
    
        $("a.tooltip").mouseover(function(e){
        //显示title
    
        var tooltip = "
    " + this.title + "起作用了
    "
    ;//创建
    $("body").append(tooltip);//将它追加到文档中 $("#tooltip").css({ "top" : e.pageY + "px", "left" : e.pageX + "px", "position":"absolute" }).show("fast");//设置x,y坐标和位置属性并且显示 }).mouseout(function(){ //隐藏title $("#tooltip").remove();//移除 }); })

    此时的效果有两个问题:首先是当鼠标滑过后,标签中的title属性的提示也会出现:
    其次是设置x和y坐标的问题,由于自制的提示与鼠标的距离太近,有时候会引起无法提示的问题(鼠标焦点变化引起mouseout事件)。
    为了移除标签中的title提示功能,需要进行以下几个步骤。
    (1)当鼠标滑入时,给对象添加一个新属性,并把title的值传给这个属性,然后清空属性title的值。
    (2)当鼠标滑出时,再把对象的myTitle属性的值又赋给属性tile。

    为了解决第2个问题,需要重新设置提示元素的top和left的值。
    
    解决了两个问题后的代码:
    
    $(function(){//网页加载时运行
        var x = 10;//鼠标值的x偏移量
        var y = 20;//鼠标值的y偏移量
        $("a.tooltip").mouseover(function(e){
        //显示title
        this.myTitle = this.title;
        this.title = "";
    
        var tooltip = "
    " + this.myTitle + "起作用了
    "
    ;//创建
    $("body").append(tooltip);//将它追加到文档中 $("#tooltip").css({ "top" : (e.pageY + y ) + "px", "left" : (e.pageX + x ) + "px", "position":"absolute" }).show("fast");//设置x,y坐标和位置属性并且显示 }).mouseout(function(){ //隐藏title this.title = this.myTitle; $("#tooltip").remove();//移除 }); })

    此时,鼠标滑入和滑出显示已经没有问题了,但当鼠标在超链接上移动时,提示效果并不会更随鼠标移动。如果需要提示效果更随鼠标一起移动,可以为超链接加上

    一个mousemove事件,解决在超链接上问题后的代码如下:

    $(function(){//网页加载时运行
        var x = 10;//鼠标值的x偏移量
        var y = 20;//鼠标值的y偏移量
        $("a.tooltip").mouseover(function(e){
        //显示title
        this.myTitle = this.title;
        this.title = "";
    
        var tooltip ="
    " + this.myTitle + "起作用了
    "
    ;//创建
    $("body").append(tooltip);//将它追加到文档中 $("#tooltip").css({ "top" : (e.pageY + y ) + "px", "left" : (e.pageX + x ) + "px", "position":"absolute" }).show("fast");//设置x,y坐标和位置属性并且显示 }).mouseout(function(){ //隐藏title this.title = this.myTitle; $("#tooltip").remove();//移除 }).mousemove(function(e){ //超链接上, //必须修改位置的值。 $("#tooltip").css({ "top" : (e.pageY + y ) + "px", "left" : (e.pageX + x ) + "px", }); }); })

    完整的代码如下:

    
    <html>
      <head>
        <title>MyHtml.htmltitle>
    
            <script src="jquery-1.11.3.js" type="text/javascript">      
    
            script>
    
        <script type="text/javascript">
    $(function(){//网页加载时运行
        var x = 10;//鼠标值的x偏移量
        var y = 20;//鼠标值的y偏移量
        $("a.tooltip").mouseover(function(e){
        //显示title
        this.myTitle = this.title;
        this.title = "";
    
        var tooltip = "
    " + this.myTitle + "起作用了
    "
    ;//创建
    $("body").append(tooltip);//将它追加到文档中 $("#tooltip").css({ "top" : (e.pageY + y ) + "px", "left" : (e.pageX + x ) + "px", "position":"absolute" }).show("fast");//设置x,y坐标和位置属性并且显示 }).mouseout(function(){ //隐藏title this.title = this.myTitle; $("#tooltip").remove();//移除 }).mousemove(function(e){ //超链接上, //必须修改位置的值 $("#tooltip").css({ "top" : (e.pageY + y ) + "px", "left" : (e.pageX + x ) + "px", }); }); }) script> head> <body> <p> <a href="#" class="tooltip" title="这是我的超链接提示1.">提示1.a> p> <p> <a href="#" class="tooltip" title="这是我的超链接提示2.">提示2.a> p> <p> <a href="#" title="这是自带的超链接提示1.">提示1.a> p> <p> <a href="#" title="这是自带的超链接提示2.">提示2.a> p> body> html>

    2.图片提示效果

    稍微修改上面的代码,就可以做出一个图片的提示效果。
    首先在空白网页中加入图片,HTML代码如下:

    <ul>
            <li><a href="images/phone2.png" class="tooltip" title="iphone手机"><img  src="images/phone.png" alt="iphone手机" >a>li>
            <li><a href="images/man1.jpg" class="tooltip" title="man"><img  src="images/logo.png" alt="logo" >a>li>
        ul>

    我们只要稍稍修改一下上面的代码就可以实现了。

    var tooltip ="<div id='tooltip'>" + this.myTitle + "起作用了div>";//创建<div>
    
        改为:
        var tooltip ="<div id='tooltip'><img src='"+this.href+"' alt='产品预览图'/>div>";//创建<div>

    为了使效果更为人性化,还需要添加说明文字,即图片下面还有相应的介绍文字
    可以根据超链接的title属性值来获取图片相应的介绍文字;

    解决关键代码如下:
    
    this.myTitle = this.title;
        this.title = "";
        var imgTitle = this.myTitle?"
    "
    + this.myTitle : "" ;//如果标题存在就取标题,不存在就没有介绍文字。 var tooltip ="
    产品预览图" + imgTitle + "
    "
    ;//创建

    图片预览的全部代码如下:

    
    <html>
      <head>
        <title>MyHtml.htmltitle>
    
            <script src="jquery-1.11.3.js" type="text/javascript">      
    
            script>
    
        <script type="text/javascript">
    $(function(){//网页加载时运行
        var x = 10;//鼠标值的x偏移量
        var y = 20;//鼠标值的y偏移量
        $("a.tooltip").mouseover(function(e){
        //显示title
        this.myTitle = this.title;
        this.title = "";
    
        var imgTitle = this.myTitle?"
    "
    + this.myTitle : "" ;//如果标题存在就取标题,不存在就没有介绍文字。 var tooltip ="
    产品预览图" + imgTitle + "
    "
    ;//创建
    $("body").append(tooltip);//将它追加到文档中 $("#tooltip").css({ "top" : (e.pageY + y ) + "px", "left" : (e.pageX + x ) + "px", "position":"absolute" }).show("fast");//设置x,y坐标和位置属性并且显示 }).mouseout(function(){ //隐藏title this.title = this.myTitle; $("#tooltip").remove();//移除 }).mousemove(function(e){ //超链接上, //必须修改位置的值 $("#tooltip").css({ "top" : (e.pageY + y ) + "px", "left" : (e.pageX + x ) + "px", }); }); }) script> head> <body> <ul> <li><a href="images/phone2.png" class="tooltip" title="iphone手机"><img src="images/phone.png" alt="iphone手机" >a>li> <li><a href="images/man1.jpg" class="tooltip" title="man"><img src="images/logo.png" alt="logo" >a>li> ul> body> html>

    四、总结

    本结开始介绍了什么是DOM,然后介绍了DOM操作分为DOM Core操作、HTML-DOM操作和CSS-DOM操作,以及它们的功能和用法,然后详细地介绍了jquery中的DOM操作,例如:如何创建节点、设置属性等,最后以一个超链接提示和图片提示作为案例,加深对DOM的理解。

    你可能感兴趣的:(jQuery,Web前端开发)