IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> JavaScript知识库 -> Javascript 学习之路9 第九章 DOM优化和拓展 -> 正文阅读

[JavaScript知识库]Javascript 学习之路9 第九章 DOM优化和拓展

还在学习中

<!DOCTYPE html>
<html>
	<head>
		<meta charset="utf-8" />
		<title></title>
		<style>
			ul,li{
				margin: 0;
				padding: 0;
			}
			.red{
				color: white;
				background-color: red;
			}
			p{
				border: 1px solid green;
				background-color: yellow;
				margin: 5px;
			}
			#outer{
				width: 450px;
				margin: 10px auto;
				height: auto;
			}
			#tab{
				background-color: #000;
				border: 1px solid #000;
				overflow: auto; /* 因为内容是浮动的所以不会占据位置导致默认高度为0,无法显示出来,所以增加此属性 */
			}
			#tab li{
				float: left;
				color: #fff;
				height: 30px;
				list-style-type: none;
				padding: 0 20px;
			}
			#tab li.current{
				color: #000;
				background-color: #ccc;
			}
			#content ul{
				display: none;
			}
		</style>
	</head>
	<body>
		<!--DOM操作
		1.先遍历完数组,然后一次性在DOM上操作
		2.大范围操作先把容器隐藏,在其中操作完成后,再显示
		3.样式操作不要主意修改属性,直接替换class
		4.用变量保存DOM属性,而不是多次获取
		-->
		 <ul id="nav">
			 
		 </ul>
		 <script type="text/javascript">
		 	var list = document.getElementById("nav");
			var fragment = document.createDocumentFragment();
			for(var i=0; i<6; i++){
				var item = document.createElement("li");
				item.appendChild(document.createTextNode("option"+i))
				fragment.appendChild(item);
			}
			list.appendChild(fragment);
		 </script>
		 <!--按钮功能实现推荐方法-->
		 <button id="btn" type="button">ok</button>
		 <script type="text/javascript">
		 	function showFn(){
				alert("Hello World")
			}
			function show(){
				alert("Thankyou")
			}
			var btn = document.getElementById("btn");
			btn.addEventListener("click",showFn,false);
			btn.addEventListener("click",show,false);
			//btn.removeEventListener('click',showFn,false);
			//为了兼容IE8以下版本
			//btn.attachEvent("onclick",showFn);
			//btn.detachEvent("onclick",showFn);			
		 </script>
		 <!--DOM节点对象的事件处理-->
		 <script type="text/javascript">
			var fragment = document.createDocumentFragment();
		 	for(var i=0; i<5; i++){
				var p = document.createElement("p");
				p.onmouseover = function(){
					this.className = "red";
				}
				p.onmouseout = function(){
					this.className="";
				}
				var text = document.createTextNode("行内元素"+ i);
				p.appendChild(text)
				fragment.appendChild(p)
			}
			document.body.appendChild(fragment);
		 </script>
		 <!--新的选择方法和遍历方式-->
		 <p>第一</p>
		 <div id="t">
			 <a href="">1</a>
			 <a href="">2</a>
			 <a href="">3</a>
			 <a href="">4</a>
		 </div>
		 <p>第二</p>
		 <script type="text/javascript">
		 	var t = document.querySelector("#t");//id属性加#,class属性加.
			//alert(t.innerHTML);
			console.log(t.childElementCount);//4
			console.log(t.firstElementChild);//<a href="">1</a>
			console.log(t.lastElementChild);//<a href="">4</a>
			console.log(t.previousElementSibling);//<p>第一</p>
			console.log(t.nextElementSibling);//<p>第二</p>
		 </script>
		 <!--学会使用classlist-->
		 <div id="pq" class="aa ss dd ff"></div>
		 <button type="button" onclick="show()">show</button>
		 <script type="text/javascript">
		 	function show(){
				var pq = document.querySelector("#pq");
				pq.classList.add("gg");
				alert(pq.classList);//aa ss dd ff gg
				pq.classList.remove("aa");
				alert(pq.classList);//ss dd ff gg
				alert(pq.classList.contains("bb"));//false
				alert(pq.classList.toggle("pp"));//true
				//关于toggle用法,如果pp存在则删除返回fasle,如果pp不存在则添加,返回true
				alert(pq.classList)//ss dd ff gg pp
			}
		 </script>
		 <!--简易选项框-->
		 <div id="outer">
			 <ul id="tab">
			 	<li class="current">第一</li>
			 	<li>第二</li>
			 	<li>第三</li>
			 </ul>
			 <div id="content">
			 	<ul style="display: block;">
					<li>1</li>
					<li>1</li>
					<li>1</li>
					<li>1</li>
					<li>1</li>
				</ul>
			 	<ul>
					<li>2</li>
					<li>2</li>
					<li>2</li>
					<li>2</li>
					<li>2</li>
				</ul>
			 	<ul>
					<li>3</li>
					<li>3</li>
					<li>3</li>
					<li>3</li>
					<li>3</li>
				</ul>
			 </div>
		 </div>
		 <script type="text/javascript">
			 window.onload = function(){
				var oli = document.querySelector("#tab").getElementsByTagName("li");
				var oul = document.querySelector("#content").getElementsByTagName("ul");
				for(var i=0; i<oli.length; i++){
					oli[i].index = i
					oli[i].onmouseover = function(){
						for(var j=0; j<oli.length; j++){
							oli[j].className="";
						}
						this.className="current";
						for(var j=0; j<oli.length; j++){
							oul[j].style.display = "none";
						}
						oul[this.index].style.display = "block"
					}
				}
			 }
		 	
		 </script>
	</body>
</html>

  JavaScript知识库 最新文章
ES6的相关知识点
react 函数式组件 & react其他一些总结
Vue基础超详细
前端JS也可以连点成线(Vue中运用 AntVG6)
Vue事件处理的基本使用
Vue后台项目的记录 (一)
前后端分离vue跨域,devServer配置proxy代理
TypeScript
初识vuex
vue项目安装包指令收集
上一篇文章      下一篇文章      查看所有文章
加:2021-07-24 11:20:57  更:2021-07-24 11:22:40 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/28 11:49:02-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码