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-DOM和BOM对象 -> 正文阅读

[JavaScript知识库]JavaScript-DOM和BOM对象

学习目标

  1. 掌握JavaScript DOM对象 重点
  2. 掌握JavaScript BOM对象 重点
  3. 掌握JavaScript操作文档元素的方法
  4. 掌握JavaScript事件的原理
  5. 掌握JavaScript常用事件的运用方法 重点

JavaScript BOM对象

BOM(Browser Object Model) 是指浏览器对象模型

document对 Document 对象的只读引用。
history对 History 对象的只读引用。
navigator对 Navigator 对象的只读引用。
screen对 Screen 对象的只读引用。
location用于窗口或框架的 Location 对象。
name设置或返回窗口的名称。
innerHeight返回窗口的文档显示区的高度。
innerWidth返回窗口的文档显示区的宽度。
outerHeight返回窗口的外部高度,包含工具条与滚动条。
outerWidth返回窗口的外部宽度,包含工具条与滚动条。

Window 对象

所有 JavaScript 全局对象、函数以及变量均自动成为 window 对象的成员。全局变量是 window 对象的属性。全局函数是 window 对象的方法。甚至 HTML DOM 的 document 也是 window 对象的属性之一:

window.document.getElementById("header");
// 与此相同:
document.getElementById("header");

setInterval()

window.setInterval() 按照指定的周期(以毫秒计)来调用函数或计算表达式。

var label = setInterval(function, milliseconds, param1, param2, ...)

clearInterval()

window.clearInterval() 取消由 setInterval() 设置的 timeout。

clearInterval(label)

setTimeout()

window.setTimeout() 在指定的毫秒数后调用函数或计算表达式。

var label = setTimeout(function, milliseconds, param1, param2, ...)

clearTimeout()

window.clearTimeout() 取消由 setTimeout() 方法设置的 timeout。

clearTimeout(label)

浏览器窗口的尺寸

有三种方法能够确定浏览器窗口的尺寸。

1.对于Internet Explorer、Chrome、Firefox、Opera 以及 Safari:

window.innerHeight - 浏览器窗口的内部高度(不包括滚动条)
window.innerWidth - 浏览器窗口的内部宽度(不包括滚动条)

2.对于 Internet Explorer 8、7、6、5:

document.documentElement.clientHeight
document.documentElement.clientWidth

3.常规

document.body.clientHeight
document.body.clientWidth
案例01:获取浏览器宽高
<!DOCTYPE html>
<html>
	<head>
		<meta charset="utf-8">
		<title></title>
	</head>
	<body>
	</body>
	<script>
		var w = window.innerWidth ||
			document.documentElement.clientWidth ||
			document.body.clientWidth;
			
		var h = window.innerHeight ||
			document.documentElement.clientHeight ||
			document.body.clientHeight;
			
		document.write("浏览器window宽度: " + w + ", 高度: " + h + "。");
	</script>
</html>

效果展示
在这里插入图片描述

显示器尺寸

window.scren对象用户获取显示器的各种参数:

  • scren.width - 返回屏幕的总宽度,(包括Windows底部任务栏)
  • screen.height - 返回屏幕的总高度,(包括Windows底部任务栏)
  • screen.availWidth - 返回屏幕的高度(不包括Windows底部任务栏)
  • screen.availHeight - 返回屏幕的宽度(不包括Windows底部任务栏)
  • screen.colorDepth - 色彩深度
  • screen.pixelDepth - 色彩分辨率
案例02:获取屏幕参数
<!DOCTYPE html>
<html>
	<head>
		<meta charset="utf-8">
		<title></title>
	</head>
	<body>
	</body>
	<script>
		document.write("总宽度/高度: "+screen.width + "*" + screen.height);
		document.write("<br>");
		document.write("可用宽度/高度: "+screen.availWidth + "*" + screen.availHeight);
		document.write("<br>");
		document.write("色彩深度: "+screen.colorDepth);
		document.write("<br>");
		document.write("色彩分辨率: "+screen.pixelDepth);
	</script>
</html>

效果展示

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-oZs77oM9-1646224118228)(C:\Users\Administrator\AppData\Roaming\Typora\typora-user-images\image-20220221150818605.png)]
Location对象

window.location 对象可以获取url的各部分参数、跳转、重定向等

  • location.hostname 返回 web 主机的域名
  • location.pathname 返回当前页面的路径和文件名
  • location.port 返回 web 主机的端口 (80 或 443)
  • location.protocol 返回所使用的 web 协议(http:// 或 https://)/)
  • location.href返回完整的 URL(http://127.0.0.1:8020 /demo02/index.html)
  • location.hash 返回一个URL的锚部分
  • location.assign(url) 跳转到新文档【location.assign(“http://www.baidu.com”)】,可返回
  • location.replace(url) 用新文档取代当前文【location.replace(“http://www.baidu.com”)】
  • location.reload() 刷新(重新加载)当前文档【location.reload()】
案例03:链接属性
<!DOCTYPE html>
<html>
	<head>
		<meta charset="utf-8">
		<title></title>
	</head>
	<body>
		<button onclick="location.assign('http://www.baidu.com')">
			assign:跳转到新文档(百度),可以返回前地址
		</button>
		<br/>
		<button onclick="location.replace('http://www.baidu.com')">
			replace:用新文档(百度)替换,不可以返回前地址
		</button>
		<br/>
		<button onclick="location.reload()">
			reload:重新加载当前文档(刷新)
		</button>
		<br/>
	</body>
	<script>
		location.href = 'http://127.0.0.1/JS/014-JS/demo03/index.html?id=1$class=c#test'
		document.write("完整地址: "+location.href);
		document.write("<br>");
		document.write("协议: "+location.protocol);
		document.write("<br>");
		document.write("主机和端口: "+ location.host);
		document.write("<br>");
		document.write("主机地址: "+ location.hostname);
		document.write("<br>");
		document.write("端口: "+location.port);
		document.write("<br>");
		document.write("当前文件路径: "+location.pathname);
		document.write("<br>");
		document.write("搜索(参数): "+location.search);
		document.write("<br>");
		document.write("锚点: "+location.hash);
		document.write("<br>");
	</script>
</html>

效果展示

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-vqdhqsrx-1646224137605)(C:\Users\Administrator\AppData\Roaming\Typora\typora-user-images\image-20220221150841157.png)]
历史记录对象

window.history对象可以操作历史记录,前进后退等

  • history.back() - 与在浏览器点击后退按钮相同
  • history.forward() - 与在浏览器中点击向前按钮相同
  • history.go(number|URL) - 加载某个具体页面(正数:向前;负数:向后)
案例04:回到历史记录

文件一

<!DOCTYPE html>
<html>
	<head>
		<meta charset="utf-8">
		<title></title>
	</head>
	<body>
		<div>
			页面1
		</div>
		<a href="new_file1.html">跳转到页面1</a>
		<button onclick="history.forward();">下一页面</button>
	</body>
</html>

文件二

<!DOCTYPE html>
<html>
	<head>
		<meta charset="UTF-8">
		<title></title>
	</head>
	<body>
		<div>
			页面2
		</div>
		<a href="new_file2.html">跳转到页面3</a>
		<button onclick="history.back();">上一页面</button>
		<button onclick="history.forward();">下一页面</button>
	</body>
</html>

文件三

<!DOCTYPE html>
<html>
	<head>
		<meta charset="UTF-8">
		<title></title>
	</head>
	<body>
		<div>
			页面3
		</div>
		<button onclick="history.back();">返回上一页面</button>
		<button onclick="history.go(-2);">返回第一页</button>
	</body>
</html>

浏览器对象

Window.navigator对象用户获取当前浏览器的各种参数

  • navigator.appCodeName - 返回浏览器的代码名
  • navigator.appName - 返回浏览器的名称
  • navigator.appVersion - 返回浏览器的平台和版本信息
  • navigator.cookieEnabled - 返回指明浏览器中是否启用 cookie 的布尔值
  • navigator.platform - 返回运行浏览器的操作系统平台
  • navigator.userAgent - 返回由客户机发送服务器的user-agent 头部的值
  • navigator.javaEnabled() - 指定是否在浏览器中启用Java
  • navigator.taintEnabled() - 规定浏览器是否启用数据污点(data tainting)
案例05:获取浏览器参数
<!DOCTYPE html>
<html>
	<head>
		<meta charset="UTF-8">
		<title></title>
	</head>
	<body>
	</body>
	<script type="text/javascript">
		document.write("浏览器代号: " + navigator.appCodeName + "<br/><br/>");
		document.write("浏览器名称: " + navigator.appName + "<br/><br/>");
		document.write("浏览器的平台和版本信息: " + navigator.appVersion + "<br/><br/>");
		document.write("浏览器启用cookie: " + navigator.cookieEnabled + "<br/><br/>");
		document.write("HTTP 请求的用户代理头: " + navigator.userAgent + "<br/><br/>");
	</script>
</html>

效果展示

JavaScript DOM对象

文档对象模型 (DOM),将 web 页面与到脚本或编程语言连接起来

Document 对象

属性 / 方法描述
document.addEventListener()向文档添加事件句柄
document.removeEventListener()移除文档中的事件句柄(由 addEventListener() 方法添加)
document.body返回文档的body元素
document.cookie设置或返回与当前文档有关的所有 cookie。
document.createAttribute()创建一个属性节点
document.createComment()createComment() 方法可创建注释节点。
document.createElement()创建元素节点。
document.createTextNode(xxxx)创建文本节点。
document.getElementsByClassName()返回文档中所有指定类名的元素集合,作为 NodeList 对象。
document.getElementById()返回对拥有指定 id 的第一个对象的引用。
document.getElementsByName()返回带有指定名称的对象集合。
document.getElementsByTagName()返回带有指定标签名的对象集合。
document.querySelector()返回文档中匹配指定的CSS选择器的第一元素
document.querySelectorAll()document.querySelectorAll() 是 HTML5中引入的新方法,返回文档中匹配的CSS选择器的所有元素节点列表
document.write()向文档写 HTML 表达式 或 JavaScript 代码。
document.writeln()等同于 write() 方法,不同的是在每个表达式之后写一个换行符。

Element对象

属性 / 方法描述
element.addEventListener()向指定元素添加事件句柄
element.removeEventListener()移除由 addEventListener() 方法添加的事件句柄
element.appendChild(node)为元素添加一个新的子元素
element.removeChild(node)删除一个子元素
element.insertBefore(node,newnode)现有的子元素之前插入一个新的子元素
element.classList返回元素的类数组,可用add(class1, class2, …)、contains(class)、item(index)、remove(class1, class2, …)、toggle(class)
element.className设置或返回元素的class属性值
element.id设置或者返回元素的 id。
element.attributes返回一个元素的属性数组
element.innerHTML设置或者返回元素的内容。
element.getAttribute(name)返回指定元素的属性值
element.getAttributeNode(name)返回指定属性节点对象,name:属性名;value:属性值
element.hasAttribute(name)判断元素中是否存在指定的属性返回 true,否则返回false。
element.hasAttributes()判断元素是否有任何属性返回true,否则返回false。
element.hasChildNodes()判断元素是否具有任何子元素
element.removeAttribute()从元素中删除指定的属性
element.removeAttributeNode()删除指定属性节点并返回移除后的节点。
element.setAttribute()设置或者改变指定属性并指定值。
element.setAttributeNode()设置或者改变指定属性节点。
element.clientHeight在页面上返回内容的可视高度(不包括边框,边距或滚动条)
element.clientWidth在页面上返回内容的可视宽度(不包括边框,边距或滚动条)
element.offsetHeight返回,任何一个元素的高度包括边框和填充,但不是边距
element.offsetWidth返回元素的宽度,包括边框和填充,但不是边距
element.scrollHeight返回整个元素的高度(包括带滚动条的隐蔽的地方)
element.offsetTop返回元素距离顶部的高度
element.offsetLeft返回元素距离左边的宽度
element.scrollLeft返回当前视图中的实际元素的左边缘和左边缘之间的距离
element.scrollTop返回当前视图中的实际元素的顶部边缘和顶部边缘之间的距离
element.scrollWidth返回元素的整个宽度(包括带滚动条的隐蔽的地方)
element.cloneNode(boolean)克隆某个元素,true:克隆子元素;false:不包括子元素
element.childNodes返回元素的一个子节点的数组,包括空文字节点
element.children返回元素的一个子节点的数组,不包括空文字节点
element.firstChild返回元素的第一个子节点
element.lastChild返回的最后一个子元素
element.nextSibling返回该元素紧跟的一个节点
element.parentNode返回元素的父节点element.parentElement
element.previousSibling返回某个元素紧接之前元素
element.querySelector()返回匹配指定 CSS 选择器元素的第一个子元素

经典案例:显示隐藏

<!DOCTYPE html>
<html>
	<head>
		<meta charset="utf-8">
		<title></title>
		<style type="text/css">
			.hide{display: none;}
		</style>
	</head>
	<body>
		<input type="text" id="a" class="hide"/>
		<button onclick="change(this)">切换</button>
	</body>
	<script type="text/javascript">
		// 方法1 : 计数求模
		count = 0
		function change(that){
			if (count++ % 2 == 0) {
				a.classList.add("b1")
			} else{
				a.classList.remove("b1")
			}
		}
		// 方法2 : 属性记录状态
		function change(that){
			if (that.getAttribute("isShow") == "true") {
				a.classList.add("b1")
				that.setAttribute("isShow","false")
			} else{
				a.classList.remove("b1")
				that.setAttribute("isShow","true")
			}
		}
		// 方法3 : 类列表切换 class 属性
		function change(that){
			a.classList.toggle("b1")
		}
	</script>
</html>

案例06:切换class

<!DOCTYPE html>
<html>
	<head>
		<meta charset="utf-8">
		<title> </title>
		<style>
			.mystyle {
				width: 300px;
				height: 50px;
				background-color: coral;
				color: white;
				font-size: 25px;
			}
			
			.newClassName {
				width: 400px;
				height: 100px;
				background-color: lightblue;
				text-align: center;
				font-size: 25px;
				color: navy;
				margin-bottom: 10px;
			}
		</style>
	</head>
	<body>
		<button onclick="myFunction()">点击按钮切换添加/删除类名</button>

		<div id="myDIV" class="mystyle">
			我是一个 DIV 元素。
		</div>
		<script>
			function myFunction() {
				document.getElementById("myDIV").classList.toggle("newClassName");
			}
		</script>
	</body>
</html>

效果展示

在这里插入图片描述

案例07:动态添加元素

<!DOCTYPE html>
<html>

	<head>
		<meta charset="utf-8">
		<title></title>
	</head>

	<body>

		<ul id="myList1">
			<li>你好</li>
			<li>哈哈</li>
		</ul>
		<ul id="myList2">
			<li>嘎嘎</li>
			<li>嘿嘿</li>
		</ul>

		<button onclick="myFunction()">单击按钮将项目从一个列表复制到另一个列表中</button>
		<script>
			function myFunction() {
				var itm = document.getElementById("myList2").children;
				var cln = itm[itm.length-1].cloneNode(true);
				document.getElementById("myList1").appendChild(cln);
			}
		</script>

	</body>

</html>

效果展示
在这里插入图片描述

Event对象

属性此事件发生在何时…
onblur元素失去焦点。
onchange域的内容被改变。
onclick当用户点击某个对象时调用的事件句柄。
ondblclick当用户双击某个对象时调用的事件句柄。
onfocus元素获得焦点。
onkeydown某个键盘按键被按下。
onkeypress某个键盘按键被按下并松开。
onkeyup某个键盘按键被松开。
onload一张页面或一幅图像完成加载。
onmousedown鼠标按钮被按下。
onmousemove鼠标被移动。
onmouseout鼠标从某元素移开。
onmouseover鼠标移到某元素之上。
onmouseup鼠标按键被松开。
onresize窗口或框架被重新调整大小。
onunload用户退出页面。
onscroll页面滚动

鼠标 / 键盘属性

属性描述
clientX返回当事件被触发时,鼠标指针的水平坐标。
clientY返回当事件被触发时,鼠标指针的垂直坐标。
screenX返回当某个事件被触发时,鼠标指针的水平坐标。
screenY返回当某个事件被触发时,鼠标指针的垂直坐标。

标准 Event 方法

方法描述
preventDefault()不执行与事件关联的默认事件。
stopPropagation()不再向上(子元素)传递事件

案例08:鼠标坐标

<!DOCTYPE html>
<html>
	<head>
		<meta charset="UTF-8">
		<title></title>
		<style type="text/css">
			html,body{
				height: 100%;
			}
		</style>
	</head>
	<body onmousemove="show_coords(event)">
	</body>
	<script type="text/javascript">
		function show_coords(event) {
			x = event.clientX;
			y = event.clientY;
			document.body.innerHTML= "X 坐标: " + x + ", Y 坐标: " + y;
		}
	</script>
</html>

效果图
在这里插入图片描述

  JavaScript知识库 最新文章
ES6的相关知识点
react 函数式组件 & react其他一些总结
Vue基础超详细
前端JS也可以连点成线(Vue中运用 AntVG6)
Vue事件处理的基本使用
Vue后台项目的记录 (一)
前后端分离vue跨域,devServer配置proxy代理
TypeScript
初识vuex
vue项目安装包指令收集
上一篇文章      下一篇文章      查看所有文章
加:2022-03-03 16:03:16  更:2022-03-03 16:03:59 
 
开发: 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/10 10:20:29-

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