一步一步学习 JQuery (五) 用JQuery玩转节点

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 对象的各种属性

1.查找节点

查找节点: 
查找属性节点: 通过 jQuery 选择器完成.
操作属性节点: 查找到所需要的元素之后, 可以调用 jQuery 对象的 attr() 方法来获取它的各种属性值
操作文本节点:通过 text() 方法

<span style="font-size:14px;"><html>
	<head>
		<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
		<title>Untitled Document</title>
		
		<script type="text/javascript" src="jquery-1.9.1.js"></script>
		<script type="text/javascript">
			
			//测试使用 jQuery 操作文本节点, 属性节点. 
			//即查找元素节点
			
			$(function(){
				//1. 操作文本节点: 通过 jQuery 对象的 text() 方法
				alert($("#bj").text());
				$("#bj").text("WWW");
				
				//2. 操作属性节点: 通过 jQuery 对象的 attr() 方法. 
				//注: 直接操作 value 属性值可以使用更便捷的 val() 方法. 
				alert($(":text[name='username']").attr("value"));
				$(":text[name='username']").attr("value", "OK");
			})
			
		</script>
		
	</head>
	<body>
		<p>你喜欢哪个城市?</p>
		<ul id="city"><li id="bj">北京</li>
			<li>上海</li>
			<li id="dj">东京</li>
			<li id="se">首尔</li>
		</ul>
		
		<br><br>
		<p>你喜欢哪款单机游戏?</p>
		<ul id="game">
			<li id="rl">红警</li>
			<li>实况</li>
			<li>极品飞车</li>
			<li>魔兽</li>
		</ul>
		<br><br>
		gender: 
			<input type="radio" name="gender" value="male"/>Male
			<input type="radio" name="gender" value="female"/>Female
		<br><br>
		name: <input type="text" name="username" value="at"/>
		
	</body>
</html>	</span>

2.创建节点

创建节点: 使用 jQuery 的工厂函数 $(): $(html); 会根据传入的 html 标记字符串创建一个 DOM 对象, 并把这个 DOM 对象包装成一个 jQuery 对象返回.
注意: 
动态创建的新元素节点不会被自动添加到文档中, 而是需要使用其他方法将其插入到文档中; 
当创建单个元素时, 需注意闭合标签和使用标准的 XHTML 格式. 例如创建一个<p>元素, 可以使用 $(“<p/>”) 或 $(“<p></p>”), 但不能使用 $(“<p>”) 或 $(“<P>”)
创建文本节点就是在创建元素节点时直接把文本内容写出来; 创建属性节点也是在创建元素节点时一起创建

<span style="font-size:14px;"><html>
	<head>
		<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
		<title>Untitled Document</title>
		
		<script type="text/javascript" src="jquery-1.9.1.js"></script>
		<script type="text/javascript">
			
			//测试使用 jQuery 创建节点并插入节点到指定的节点中
			/*
			1. 创建节点: 使用 $(html) 方式即可, 元素节点, 文本节点, 属性节点可以一网打尽
			返回对应节点的 jQuery 对象:
			$("<li id='at'>哇哈哈</li>")
			注:创建节点,要注意闭合标签和使用标准的 XHTML 格式. 
			2. 添加节点:
			1). appendTo 和 append: 主语和宾语的位置不同:  
			$("<li id='at'>哇哈哈</li>").appendTo($("#city"));	
			$("#city").append("<li id='at'>[哇哈哈]</li>");
			
			2). prependTo 和  prepend: 主语和宾语的位置不同: 
			//把 哇哈哈 添加到 city 里
			$("<li id='at'>哇哈哈</li>").prependTo($("#city"));
			//city 添加一个 哇哈哈
			$("#city").prepend("<li id='at'>[哇哈哈]</li>");	
			*/
			$(function(){
				//1. 创建一个 <li id="at">哇哈哈</li>
				//2. 并把其加入到 #city 的子节点
				//$("<li id='at'>哇哈哈</li>").appendTo($("#city"));
				//$("#city").append("<li id='at'>[哇哈哈]</li>");

				//$("<li id='at'>哇哈哈</li>").prependTo($("#city"));
				$("#city").prepend("<li id='at'>[哇哈哈]</li>");
				alert($("#at").text());
			})

		</script>
	</head>
	<body>
		<p>你喜欢哪个城市?</p>
		<ul id="city"><li id="bj">北京</li>
			<li>上海</li>
			<li id="dj">东京</li>
			<li id="se">首尔</li>
		</ul>
		<br><br>
		<p>你喜欢哪款单机游戏?</p>
		<ul id="game">
			<li id="rl">红警</li>
			<li>实况</li>
			<li>极品飞车</li>
			<li>魔兽</li>
		</ul>	
		<br><br>
		gender: 
			<input type="radio" name="gender" value="male"/>Male
			<input type="radio" name="gender" value="female"/>Female
		<br><br>
		name: <input type="text" name="username" value="at"/>
	</body>
</html>	</span>
3.插入节点

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

技术分享

2.技术分享

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

<span style="font-size:14px;"><html>
	<head>
		<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
		<title>Untitled Document</title>
		
		<script type="text/javascript" src="jquery-1.9.1.js"></script>
		<script type="text/javascript">
			
			//测试使用 jQuery 插入节点,使创建的节点可以插入到指定的位置
			$(function(){
				//1. 创建一个 <li id="at"></li>
				//2. 并把其加入到 #bj 的后面
				//$("<li id='at'>[WWW]</li>").insertAfter($("#bj"));
				//$("#bj").after("<li id='at'>[WWW]</li>");

				$("<li id='at'>WWWW</li>").insertBefore($("#bj"));
			//	$("#bj").before("<li id='at'>[WWW]</li>");
			})
			
		</script>
	</head>
	<body>
		<p>你喜欢哪个城市?</p>
		<ul id="city"><li id="bj">北京</li>
			<li>上海</li>
			<li id="dj">东京</li>
			<li id="se">首尔</li>
		</ul>
		
		<br><br>
		<p>你喜欢哪款单机游戏?</p>
		<ul id="game">
			<li id="rl">红警</li>
			<li>实况</li>
			<li>极品飞车</li>
			<li>魔兽</li>
		</ul>
		
		<br><br>
		gender: 
			<input type="radio" name="gender" value="male"/>Male
			<input type="radio" name="gender" value="female"/>Female
	
		<br><br>
		name: <input type="text" name="username" value="at"/>
		
	</body>
</html>	</span>
4.删除节点

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

<span style="font-size:14px;"><html>
	<head>
		<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
		<title>Untitled Document</title>
		
		<script type="text/javascript" src="jquery-1.9.1.js"></script>
		<script type="text/javascript">
			
			//测试使用 jQuery 删除节点
			$(function(){
				//为li节点添加一个相应函数,点击则删除
				//使用JQuery对象的remove()方法,可以把 jquery对象 对应的DOM节点删除
				/* $("li").click(function(){
					$(this).remove();
				}); */
				
				//$("#bj").remove();
				
				//清空game
				//jquery 的 empty() 方法: 将jquery对象对应的DOM节点的所有子节点
				//全部删除
				alert("清空所有的game!");
				$("#game").empty();
			})
			
		</script>
	</head>
	<body>
		<p>你喜欢哪个城市?</p>
		<ul id="city"><li id="bj">北京</li>
			<li>上海</li>
			<li id="dj">东京</li>
			<li id="se">首尔</li>
		</ul>
		
		<br><br>
		<p>你喜欢哪款单机游戏?</p>
		<ul id="game">
			<li id="rl">红警</li>
			<li>实况</li>
			<li>极品飞车</li>
			<li>魔兽</li>
		</ul>
		
		<br><br>
		gender: 
			<input type="radio" name="gender" value="male"/>Male
			<input type="radio" name="gender" value="female"/>Female
	
		<br><br>
		name: <input type="text" name="username" value="at"/>
		
	</body>
</html>	</span>
5.复制节点

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

<span style="font-size:14px;"><!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/strict.dtd">
<html>
	<head>
		<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
		<title>Untitled Document</title>
		
		<script type="text/javascript" src="jquery-1.9.1.js"></script>
		<script type="text/javascript">
			
			//测试使用 jQuery clone 方法: 复制节点
			$(function(){
				
				$("li").click(function(){
					alert($(this).text());
				});
				
				//复制 #bj 节点, 并添加到 #rl 节点的后面
				/*
				1. clone 节点时需要注意克隆后的节点的 id 属性. 若原节点有 id
				属性, 则克隆后, 会出现在一个文档中有两个 id 相同的节点的情况.
				2. clone(true): 在克隆节点的同时, 克隆节点包含的事件. 
				*/
				$("#bj").clone(true)
				        .attr("id", "bj2")
				        .insertAfter($("#rl"));
				
			})
			
		
		</script>
		
	</head>
	<body>
		<p>你喜欢哪个城市?</p>
		<ul id="city">
			<li id="bj" name="BeiJing">北京</li>
			<li>上海</li>
			<li id="dj">东京</li>
			<li id="se">首尔</li>
		</ul>
		
		<br><br>
		<p>你喜欢哪款单机游戏?</p>
		<ul id="game">
			<li id="rl">红警</li>
			<li>实况</li>
			<li>极品飞车</li>
			<li>魔兽</li>
		</ul>
		
		<br><br>
		gender: 
			<input type="radio" name="gender" value="male"/>Male
			<input type="radio" name="gender" value="female"/>Female
	
		<br><br>
		name: <input type="text" name="username" value="at"/>
		
	</body>
</html>	</span>
6.替换节点

replaceWith(): 将所有匹配的元素都替换为指定的 HTML 或 DOM 元素
replaceAll(): 颠倒了的 replaceWith() 方法.
注意: 若在替换之前, 已经在元素上绑定了事件, 替换后原先绑定的事件会与原先的元素一起消失

<span style="font-size:14px;"><html>
	<head>
		<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
		<title>Untitled Document</title>
		
		<script type="text/javascript" src="jquery-1.9.1.js"></script>
		<script type="text/javascript">
			
			//测试使用 jQuery replaceWith (replaceAll) 方法: 替换节点
			/*
			1. replaceWith , replaceAll 一对方法, 可以完成一件事. 就是主语宾语
			哪个在前面的问题. replaceWith:我替换谁  replaceAll 谁替换了所有的我
			2. 以上的两个方法还有移动节点的功能
			3. 节点互换需要先克隆节点. 
			4. var $rl = $("#rl").replaceWith($bj2);
			*/
			$(function(){
				
				 //1. 创建一个 <li>WWW</li> 节点, 替换 #city 的最后一个 li 子节点
				$("<li>WWW</li>").replaceAll($("#city li:last"));
				//replaceAll() 返回的是 新节点对象
				//2. 创建一个 <li>[WWW]</li> 节点, 
				//替换 #city 的第二个 li 子节点
				$("#city li:eq(1)").replaceWith($("<li>[WWW]</li>"));
				//3. 互换以下两个节点: #rl 和 #bj. 还有移动的功能.
				//用红警替换北京
				//$a = $("#bj").replaceWith($("#rl"));返回值是被替换的节点
				//alert($a.text());
				 //节点互换需要先克隆节点. 
				 alert(1);
				var $bj2 = $("#bj").clone(true);
				var $rl = $("#rl").replaceWith($bj2);
				
				alert(2);
				$("#bj").replaceWith($rl); 
			})
			
		
		</script>
		
	</head>
	<body>
		<p>你喜欢哪个城市?</p>
		<ul id="city">
			<li id="bj" name="BeiJing">北京</li>
			<li>上海</li>
			<li id="dj">东京</li>
			<li id="se">首尔</li>
		</ul>
		
		<br><br>
		<p>你喜欢哪款单机游戏?</p>
		<ul id="game">
			<li id="rl">红警</li>
			<li>实况</li>
			<li>极品飞车</li>
			<li>魔兽</li>
		</ul>
		
		<br><br>
		gender: 
			<input type="radio" name="gender" value="male"/>Male
			<input type="radio" name="gender" value="female"/>Female
	
		<br><br>
		name: <input type="text" name="username" value="at"/>
		
	</body>
</html>	</span>
7.包裹节点

wrap(): 将指定节点用其他标记包裹起来. 该方法对于需要在文档中插入额外的结构化标记非常有用, 而且不会破坏原始文档的语义.
wrapAll(): 将所有匹配的元素用一个元素来包裹. 而 wrap() 方法是将所有的元素进行单独包裹.
wrapInner(): 将每一个匹配的元素的子内容(包括文本节点)用其他结构化标记包裹起来.

<span style="font-size:14px;"><html>
	<head>
		<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
		<title>Untitled Document</title>
		
		<script type="text/javascript" src="jquery-1.9.1.js"></script>
		<script type="text/javascript">
			
			//测试使用 jQuery wrap, wrapAll, wrapInner
			$(function(){
				//包装 li 本身,就是把game 中的每一个li 都包起来
				$("#game li").wrap("<font color='red'></font>");
				
				//包装所有的 li ,把city的所有 li 一起包起来
				$("#city li").wrapAll("<font color='red'></font>");

				//包装 li 里边的文字. 
				$("#language li").wrapInner("<font color='red'></font>");
			})
			
		
		</script>
		
	</head>
	<body>
		<p>你喜欢哪个城市?</p>
		<ul id="city">
			<li id="bj" name="BeiJing">北京</li>
			<li>上海</li>
			<li id="dj">东京</li>
			<li id="se">首尔</li>
		</ul>
		
		<br><br>
		<p>你喜欢哪款单机游戏?</p>
		<ul id="game">
			<li id="rl">红警</li>
			<li>实况</li>
			<li>极品飞车</li>
			<li>魔兽</li>
		</ul>
		
		<br><br>
		<p>你喜欢哪种开发语言?</p>
		<ul id="language">
			<li>C</li>
			<li>Java</li>
			<li>.NET</li>
			<li>PHP</li>
		</ul>
		
		<br><br>
		gender: 
			<input type="radio" name="gender" value="male"/>Male
			<input type="radio" name="gender" value="female"/>Female
	
		<br><br>
		name: <input type="text" name="username" value="at"/>
		
	</body>
</html>	</span>


郑重声明:本站内容如果来自互联网及其他传播媒体,其版权均属原媒体及文章作者所有。转载目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。