DOM(三):Element属性与方法

DOM之Element及Document公有方法与属性思维导图

Dom-Document-Element.png


DOM之Element属性


element.attributes 属性及其方法

element.attributes单个属性的引用

element.attributes返回的结果是一个『伪数组』,与element.getAttributeNames()获取的结果相似,后者是『数组』形式表现出来

实例演示

<div id="test">
 <p class="para1">Hello World</p>
 <p class="para2">just test</p>
 <p class="para3">for DOM</p>
</div>
<script>
  var Div = documentGetElementById('test')
  var attr = Div.attributes
  // NamedNodeMap {0: id, id: id, length: 1}
    
  // 获取单个属性,三种方式
    attr.id
    // id="test"
    attr[0]
    // id="test"
    attr['id']
    // id="test"
</script>
element.attributes 属性的方法

Element.getAttribute()方法返回当前元素节点的指定属性(字符串)。如果指定属性不存在,则返回null

实例演示🌰

// html
/*
<div class ="xxx" id="yyy">
 test for DOM
</div>
*/

var Div = document.getElementById('yyy')

Div.getAttribute('class')
// "xxx"

Div.getAttribute('id')
// "yyy"

Div.getAttribute('width')
// null
element.getAttributeNames()

Element.getAttributeNames()返回一个『数组』,成员是当前元素的所有属性的名字

// html
/*
<div class ="xxx" id="yyy" >
 test for DOM
</div>
*/

var Div = document.getElementById('yyy')
Div.getAttributeNames()
// ["class", "id"]
element.setAttribute()

element.setAttribute()方法用于为当前元素节点新增属性。如果同名属性已存在,则相当于编辑已存在的属性。该方法没有返回值。

/*
<div class ="xxx" id="yyy" >
 test for DOM
</div>
*/

var Div = document.getElementById('yyy')

Div.setAttribute('class', 'test_again')
// <div class ="test_again" id="yyy" >,设置的同名以及存在相当于编辑已存在的属性
// 不要使用,document.createAttribute(),太繁琐
element.hasAttribute()

hasAttribute 返回一个布尔值,表示该元素是否包含有指定的属性

// html
/*
<div class ="xxx" id="yyy" >
 test for DOM
</div>
*/

var Div = document.getElementById('yyy')

Div.hasAttribute('class')
// true
// Div有 class 这个属性

Div.hasAttribute('id')
// true 
// Div有 id 这个属性

element.removeAttribute() 与element.hasAttributes()

Element.removeAttribute方法移除指定属性。该方法没有返回值。element.hasAttributes()判断当前元素『是否有』属性

// html
/*
<div class ="xxx" id="yyy" >
 test for DOM
</div>
*/

var Div = document.getElementById('yyy')


Div.removeAttribute('class')
// undefined 移除 class属性
Div.removeAttribute('id')
// undefined  移除 id 属性


// 上面已经把<div class ="xxx" id="yyy" >的属性全部删除了
var div = document.querySelector('div')
div.hasAttributes()
// false
// div 不含有任何属性 <div>test for DOM</div>

dataset 属性

元素节点对象的dataset属性,它指向一个对象,可以用来操作 HTML 元素标签的『data-属性』。

// HTML
/*
<body>
  <div class="test" data-hello-dom="test1">test for fun</div>
</body>
*/

var Div = document.querySelector('.test')

Div.dataset
// DOMStringMap {helloDom: "test1"}

Div.dataset.helloDom
// dataset.helloDom读写data-hello-dom属性。
// "test1"
// ⚠️通过dataset.*读取属性时,连词线后面如果跟着一个小写字母,那么连词线会被移除,该小写字母转为大写字母,其他字符不变⚠️
// ⚠️dataset的键名转成属性名时,所有大写字母都会被转成连词线+该字母的小写形式,其他字符不变 ataset.helloDom → data-hello-dom⚠️

Div.dataset.helloDom = "test2"
// 通过赋值改变属性
// <div class="test" data-hello-dom="test2">test for fun</div>

delete document.querySelector('.test').dataset.foo
// 删除一个data-*属性,可以直接使用delete命令。

getAttribute('data-foo')removeAttribute('data-foo')setAttribute('data-foo')hasAttribute('data-foo')等方法操作data-*属性。

注意,data-后面的属性名有限制,只能包含字母、数字、连词线(-)、点(.)、冒号(:)和下划线(_)。而且,属性名不应该使用A到Z的大写字母*


element.style(行内样式)

element.style用来读写该元素的『行内样式』信息

实例演示🌰

// html
/*
<div id="test">
 <p class="para1">Hello World</p>
 <p class="para2">just test</p>
 <p class="para3">for DOM</p>
</div>
*/


function $(selector) {
  return document.querySelector(selector)
}

var para1 = $('.para1')
var para2 = $('.para2')
var para3 = $('.para3')

// 一. 通过element.style.xxx 设置样式

para1.style.color = 'red'
// "red"
// <p class="para1" style="color: red;">Hello World</p>

para2.style.fonfSize = '30px'
// "30px"
para2.style.border = '2px solid green'
// "2px solid green"
// <p class="para2" style="font-size: 30px; border: 2px solid green;">just test</p>

para3.style.backgroundColor = 'pink'
// "pink"
// // <p class="para3" style="background-color: pink;">for DOM</p>

// 二. element.setAttribute('style','css-style')设置样式

div.setAttribute(
  'style',
  'background-color:red;' + 'border:1px solid black;'
);

element.className element.classList

document.className

属性用来读写当前元素节点的class属性。它的值是一个『字符串』,每个class之间用『空格』分割。

<p id="test1" class="lemon apple">test for dom</p>
<script>
var para = document.getElementById('test1')
test1.className
// "lemon apple"

typeof test1.className
// "string"
</script>
element.classList

element.classList属性返回一个『类似数组的对象』,当前元素节点的每个class就是这个对象的一个成员。

element.classList对象的方法 使用
element.classList.add() 增加一个 class
element.classList.remove() 移除一个 class
element.classList.contains() 检查当前元素是否包含某个 class
element.classList.item() 返回指定索引位置的 class
element.classList.toggle() 将某个 class 移入或移出当前元素,『存在某个class,就删除该class,并返回false』,不『存在该class就添加该class,并返回true』
element.classList.toString() 将 class 的列表转为字符串

实例演示🌰🌰🌰

<p id="test1" class="lemon apple">test for dom</p>
<script>
  var paraClassList = document.getElementById('test1').classList
  // DOMTokenList(2) ["lemon", "apple", value: "lemon apple"]

  typeof paraClassList          // "object"
  Array.isArray(paraClassList)  // false
  
  // 通过上面两式可以判断 『para.classList是一个类数组对象』

  paraClassList.add('banana') // 添加一个属性 「banana」
  // <p id="test1" class="lemon apple banana">test for dom</p>
  
  paraClassList.remove('banana') // 移除属性 「banana」
  // <p id="test1" class="lemon apple">test for dom</p>

  paraClassList.contains('apple') // true
  paraClassList.contains('true')  // false
 // element.classList.contains('attr'),
 // node.contains( otherNode ) ,otherNode 是否是node的后代节点。注意区分element.classList.contains()

    paraClassList.item(1)  // "apple"
    paraClassList.item(0) // "lemon"
    paraClassList.item(2) // null
  // 返回指定索引位置的 class,没有则返回null

 paraClassList.toggle('orange') // true 
 // <p id="test1" class="lemon apple orange">test for dom</p>
 // 『不存在』class="orange",就『添加』这个属性并『返回true』

 paraClassList.toggle('orange') // false 
 // <p id="test1" class="lemon apple">test for dom</p>
 // 已经『存在』class="orange"这个属性,就『删除』这个属性并『返回false』
</script>

element.innerHTML

Element.innerHTML 属性设置或获取HTML语法表示的元素的后代。⚠️⚠️⚠️为了防止恶意代码最好不使用innerHTML

element.innerHTML演示实例🌰

<body>
<input type="text" id="Input">
<button id ="inputBtn">写入</button>
<div class="display"></div>
<script>
    var Input = document.getElementById('Input')
    var inputBtn = document.getElementById('inputBtn')

    var Div = document.getElementsByClassName('display').item(0)
    // document.getElementsByClassName()获取的是一个HTMLCollection伪数组,
    // 所以想获得对应的元素就必须 通过document.getElementsByClassName('display')[0] 或是 document.getElementsByClassName('display').item(0)获取对应的HTML标签

    inputBtn.onclick = function () {
        Div.innerHTML = Input.value
        // 给<div class="display"></div>设置HTML
    }
</script>
</body>

<div class="display"></div>设置了『innerHTML = <p style="font-size: 30px; color: red;">这是一个段落</p>』,最终的结果是

HTML以及内在样式都被解析。如下图

element.innerHTML演示实例🌰

<p style="font-size: 30px; color: red;">』也被添加到『<div class="display"></div>

element.innerHTML实例


element.children

element.children『只包括元素类型的子节点』为HTMLCollection,Node.chldNodes不仅包括元素类型的子节点,也包括『空白符』,注意区分两者⚠️

<body>
<div class="test">
 <p>Hello World</p>
 <p>just test</p>
 <p class="test1">for DOM</p>
</div>
<script>
    var Div = document.querySelector('.test')
    var divElementChild = Div.children
    // HTMLCollection(3) [p, p, p.test1]

    Div.childElementCount === divElementChild.length //true
    // element.children『只包括元素类型的子节点』
    // element.childElementCount 为包含『子节点的个数』,『等于element.children.length的值』

    Div.childNodes
    // NodeList(7) [text, p, text, p, text, p.test1, text]
    // 包括元素类型的子节点,也包括『空白符』
</script>
</body>

JavaScript-DOM之Element公有方法

element.remove()

将当前元素节点从它的父节点移除,是调用自身的方法,括号内无需参数。注意区别于Node.removeChild()

代码实例

<body>
<div id="test">
<p>Hello World</p>
<p>just test</p>
<p class="test1">for DOM</p>
</div>
<script>
var Div = document.querySelector('#test')
test.lastElementChild.remove()
// <p class="test1">for DOM</p>被删除啦
// 『remove()即为自身调用自身,删除』,删除的是 element元素本身,括号内一般没参数
while (test.firstChild) {
console.log('No: ' + test.firstChild)
test.removeChild(test.firstChild)
}
// No: [object Text]
// No: [object HTMLParagraphElement]
// No: [object Text]
// No: [object HTMLParagraphElement]
// No: [object Text]

// Node.removeChild()是父元素删除子元素,删除的子元素也包括『空白符』
</script>
</body>

element.click()

用于在当前元素上模拟一次鼠标点击,相当于触发了click事件

element.insertAdjacentHTML()

element.insertAdjacentHTML(position, text); 将一个 HTML 字符串,解析生成 DOM 结构,插入相对于当前节点的指定位置。

不要死记,结合英语单词理解

位置
beforebegin 当前元素之前
beforeend 当前元素内部的最后一个子节点后面
afterbegin 当前元素内部的第一个子节点前面
afterend 当前元素之后

实例演示🌰

<div id="test">
<p class="para1">Hello World</p>
<p class="para2">just test</p>
<p class="para3">for DOM</p>
</div>
<script>
var test = document.querySelector('#test')
test.insertAdjacentHTML('beforebegin', '<p>beforebegin</p>')
// 在 <div id="test">外面的前面插入一个<p>beforebegin</p>

test.insertAdjacentHTML('beforeend', '<p>beforeend</p>')
// 在 <div id="test">内部的最后一个子节点(<p class="para3">for DOM</p>),后面插入一个<p>beforeend</p>

test.insertAdjacentHTML('afterbegin', '<p>afterbegin</p>')
// 在 <div id="test">内部的第一个子节点(<p class="para3">for DOM</p>),前面插入一个<p>afterbegin</p>

test.insertAdjacentHTML('afterend', '<p>afterend</p>')
// 在 <div id="test">外部的后面插入一个<p>afterend</p>
</script>

配图存于语雀


版权声明:本文为博主原创文章,未经博主许可不得转载

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,928评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,192评论 3 387
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 159,468评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,186评论 1 286
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,295评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,374评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,403评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,186评论 0 269
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,610评论 1 306
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,906评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,075评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,755评论 4 337
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,393评论 3 320
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,079评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,313评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,934评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,963评论 2 351