一、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></li>");//创建第一个li元素
var $li_2 = $("<li></li>");//创建第二个li元素
可以使用jQuery的append()等方法将两个新元素插入文档中。
$("ul").append($li_1).append($li_2); //添加到ul节点中,使之能在网页中显示
动态创建的新元素节点不会自动添加到文档中,而是需要使用其他方法将其插入文档中
2.创建文本节点
var $li_2 = $("<li title="香蕉">香蕉</li>");
$("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");//复制当前单击的节点,并将它追加到<ul>元素中
})
3.2.6替换节点
1.replaceWith():将所有匹配的元素都替换成指定的HTML或者DOM元素。
$("p").replaceWith("<strong>你最不喜欢的水果是?</strong>");
2.replaceAll():与replaceWith使用反过来
$("<strong>你最不喜欢的水果是?</strong>").replaceAll("p");
3.注意事项
如果在替换之前,已经为元素绑定事件,替换后原来绑定的事件将会与被替换的元素一起消失,需要在新元素上重新绑定事件
3.2.7包裹节点
如果要将某个节点用其他标记包裹起来,jQuery提供了相应的方法,即wrap().
1.wrap()方法
$("strong").wrap("<b></b>");//用b标签把strong元素包裹起来
2.wrapInner()方法
$("strong").wrapInner("<b></b>");//用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元素的class为high
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"); 移除class中 high和another样式
$("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("<strong>你最最最喜欢的水果是?</strong>");//设置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()方法该功能
<select id="single">
<option>选择1号</option>
<option>选择2号</option>
<option>选择3号</option>
</select>
<hr>
<select id="multiple" multiple="multiple" style="height:120px;">
<option selected="selected">选择1号</option>
<option>选择2号</option>
<option>选择3号</option>
<option>选择4号</option>
<option selected="selected">选择5号</option>
</select>
<hr>
<input type="checkbox" value="check1" />多选1
<input type="checkbox" value="check2" />多选2
<input type="checkbox" value="check3" />多选3
<input type="checkbox" value="check4" />多选4
<hr>
<input type="radio" value="radio1" />单选1
<input type="radio" value="radio2" />单选2
<input 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中任意一项符合就会被选中。
例如
<option value="选择2号">选择1号</option>
<option value="选择1号">选择2号</option>
无论使用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 = "<div id=‘tooltip‘>" + this.title + "起作用了</div>";//创建<div>
$("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事件)。
(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 = "<div id=‘tooltip‘>" + this.myTitle + "起作用了</div>";//创建<div>
$("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 ="<div id=‘tooltip‘>" + this.myTitle + "起作用了</div>";//创建<div>
$("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",
});
});
})
完整的代码如下:
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
<head>
<title>MyHtml.html</title>
<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 = "<div id=‘tooltip‘>" + this.myTitle + "起作用了</div>";//创建<div>
$("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?"<br />" + this.myTitle : "" ;//如果标题存在就取标题,不存在就没有介绍文字。
var tooltip ="<div id=‘tooltip‘><img src=‘"+this.href+"‘ alt=‘产品预览图‘/>" + imgTitle + "</div>";//创建<div>
图片预览的全部代码如下:
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
<head>
<title>MyHtml.html</title>
<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?"<br />" + this.myTitle : "" ;//如果标题存在就取标题,不存在就没有介绍文字。
var tooltip ="<div id=‘tooltip‘><img src=‘"+this.href+"‘ alt=‘产品预览图‘/>" + imgTitle + "</div>";//创建<div>
$("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的理解。