前面我们已经学习了如何获取节点,以及节点通常所包含的属性,接下来我们来仔细研究元素Element。
我们知道,一个元素除了有开始标签
、结束标签
、内容
之外,还有很多的属性(attribute)
浏览器在解析HTML元素时,会将对应的attribute也创建出来放到对应的元素对象上。
接下来我们学习一下如何获取和设置这些属性。
属性attribute的分类:
标准的attribute
:某些attribute属性是标准的,比如id、class、href、type、value等;非标准的attribute
:某些attribute属性是自定义的,比如abc、age、height等; <div class="box" id="main" name="kobe" abc="def" age="18">
哈哈哈哈
div>
对于所有的attribute访问都支持如下的方法:
elem.hasAttribute(name)
— 检查特性是否存在。elem.getAttribute(name)
— 获取这个特性值。elem.setAttribute(name, value)
— 设置这个特性值。elem.removeAttribute(name)
— 移除这个特性。attributes
:attr对象的集合,具有name、value属性;attribute 具备以下特征:
名字是大小写不敏感
的(id 与 ID 相同)。值总是字符串类型
的。对于标准的attribute
,会在DOM对象上创建与其对应的property
属性:
console.log(boxE1.id,boxEl.className) //box main
console.log(boxEl.abc, boxEl.age, boxEl.height) // undefined...
在大多数情况下,它们是相互作用的
property
,通过attribute获取的值,会随着改变;attribute
操作修改,property的值会随着改变;
除非特别情况,大多数情况下,设置、获取attribute,推荐使用property的方式:
默认情况下是有类型
的;toggleBtn.onclick = function () {
checkBoxInput.checked = !checkBoxInput.checked;
}
前面我们有学习HTML5的data-*
自定义属性,那么它们也是可以在dataset
属性中获取到的:
// data-*
console.log(div2El.dataset);//DOMStringMap
console.log(typeof div2El.dataset);//object
console.log(div2El.dataset.name, div2El.dataset.age);
有时候我们会通过JavaScript来动态修改样式,这个时候我们有两个选择:
动态的添加class
;动态的修改style
属性;开发中如何选择呢?
推荐使用动态class
;接下来,我们对于两种方式分别来进行学习。
元素的class attribute,对应的property并非叫class,而是className
:
不允许使用class
这种关键字来作为对象的属性,所以DOM规范使用了className;className
这个名称;我们可以对className进行赋值
,它会替换整个类中的字符串。
var boxE1 = document.querySelector(".box");
boxE1.className = "why abc";
如果我们需要添加或者移除单个的class
,那么可以使用classList
属性。
elem.classList 是一个特殊的对象
:
elem.classList.add(class)
:添加一个类elem.classList.remove(class)
:添加/移除类。elem.classList.toggle(class)
:如果类不存在就添加类,存在就移除它。elem.classList.contains(class)
:检查给定类,返回 true/false。classList是可迭代对象
,可以通过for of
进行遍历。
如果需要单独修改某一个CSS属性,那么可以通过style来操作:
多词
(multi-word)属性,使用驼峰式
(camelCase )boxEl.style.width = "100px';
boxEl.style.height = "50px";
boxE1.style.backgroundColor = "red";
如果我们将值设置为空字符串
,那么会使用CSS的默认样式
:
boxEl.style.display = "";
多个样式的写法,我们需要使用cssText
属性:
h1El.style.color = "blue";
h1El.style.border = "1px solid red";
// 会覆盖上面的color和border配置
h1El.style.cssText = "font-size: 24px";
// 1.在property中使用的驼峰格式
// console.log(boxEl.style.backgroundColor)
// 2.如果将一个属性的值, 设置为空的字符串, 那么是使用默认值
// boxEl.style.display = ""
// boxEl.style.fontSize = ""
// 3.设置多个样式
// boxEl.style.fontSize = "30px"
// boxEl.style.color = "red"
boxEl.style.cssText = "font-size: 30px; color: red;"
如果我们需要读取样式:
内联样式
,是可以通过style.*
的方式读取到的;style、css文件
中的样式,是读取不到
的;这个时候,我们可以通过getComputedStyle
的全局函数来实现:
console.log(getComputedStyle(boxEl).fontSize)
前面我们使用过 document.write
方法写入一个元素:
复杂的内容
、元素关系拼接
并不方便;那么目前我们想要插入一个元素,通常会按照如下步骤:
创建元素: document.createElement(tag)
// 创建元素
var div1El = document.createElement("div");
div1El.textContent = "我是div元素";
div1El.style.color = "red";
div1El.style.fontSize = "18px";
插入元素的方式如下:
node.append(...nodes or strings)
—— 在 node 末尾 插入节点或字符串,node.prepend(...nodes or strings)
—— 在 node 开头 插入节点或字符串,node.before(...nodes or strings)
—— 在 node 前面 插入节点或字符串,node.after(...nodes or strings)
—— 在 node 后面 插入节点或字符串,node.replaceWith(...nodes or strings)
—— 将 node 替换为给定的节点或字符串。移除元素我们可以调用元素本身的remove
方法:
如果我们想要复制一个现有的元素,可以通过cloneNode
方法:
深度克隆
;<body>
<button class="remove-btn">移除box</button>
<button class="clone-btn">复制box</button>
<div class="box">
<h2>我是标题</h2>
<p>我是文本, 哈哈哈哈哈</p>
</div>
<script>
// 1.获取元素
var boxEl = document.querySelector(".box")
var removeBtnEl = document.querySelector(".remove-btn")
var cloneBtnEl = document.querySelector(".clone-btn")
// 2.监听removeBtn的点击
removeBtnEl.onclick = function() {
boxEl.remove()
}
// 3.复制box
var counter = 0
cloneBtnEl.onclick = function() {
var newNode = boxEl.cloneNode(true)
newNode.children[0].textContent = "我是标题" + counter
// boxEl.after(newNode)
document.body.append(newNode)
counter++
}
</script>
</body>
在很多地方我们也会看到一些旧的操作方法:
parentElem.appendChild(node)
:
parentElem.insertBefore(node, nextSibling)
:
parentElem.replaceChild(node, oldChild)
:
parentElem.removeChild(node)
:
clientWidth
:contentWith+padding(不包含滚动条)
clientHeight
:contentHeight+padding
clientTop
:border-top的宽度
clientLeft
:border-left的宽度
offsetWidth
:元素完整的宽度
offsetHeight
:元素完整的高度
offsetLeft
:距离父元素的x
offsetHeight
:距离父元素的y
scrollHeight
:整个可滚动的区域高度
scrollTop
:滚动部分的高度
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Document</title>
<style>
body {
padding: 100px;
}
.box {
width: 100px;
height: 100px;
padding: 20px;
border: 10px solid red;
/* box-sizing: border-box; */
background-color: orange;
overflow: auto;
}
</style>
</head>
<body>
<div class="box">
你去过国内最美的地方是哪# 我去过国内最美的地方是新疆喀纳斯。喀纳斯是一个美丽而神秘的地方,这里群山环抱,森林密布,湖水清澈,风景奇特。为国家级5A级景区,国家地质公园,国家森林公园。
</div>
<script>
var boxEl = document.querySelector(".box")
// 1.获取样式(局限性很强)
var boxStyle = getComputedStyle(boxEl)
console.log(boxStyle.width, boxStyle.height)
// 2.获取更多信息
console.log(boxEl.clientWidth)
console.log(boxEl.clientHeight)
console.log(boxEl.clientLeft)
console.log(boxEl.clientTop)
console.log(boxEl.offsetWidth)
console.log(boxEl.offsetHeight)
console.log(boxEl.offsetLeft)
console.log(boxEl.offsetTop)
console.log(boxEl.scrollHeight)
console.log(boxEl.scrollTop)
// window对象
window.onclick = function() {
console.log(boxEl.scrollTop)
}
</script>
</body>
</html>
window的width和height
innerWidth
、innerHeight
:获取window窗口的宽度和高度(包含滚动条)outerWidth
、outerHeight
:获取window窗口的整个宽度和高度(包括调试工具、工具栏)documentElement.clientHeight
、documentElement.clientWidth
:获取html的宽度和高度(不包含滚动条)window的滚动位置:
scrollX:X
轴滚动的位置(别名pageXOffset)scrollY:Y
轴滚动的位置(别名pageYOffset)也有提供对应的滚动方法: