千鋒教育-做有情懷、有良心、有品質(zhì)的職業(yè)教育機構(gòu)

手機站
千鋒教育

千鋒學(xué)習(xí)站 | 隨時隨地免費學(xué)

千鋒教育

掃一掃進入千鋒手機站

領(lǐng)取全套視頻
千鋒教育

關(guān)注千鋒學(xué)習(xí)站小程序
隨時隨地免費學(xué)習(xí)課程

當(dāng)前位置:首頁  >  行業(yè)資訊  > JavaScript全解析——DOM操作 - 元素操作方式(上)

JavaScript全解析——DOM操作 - 元素操作方式(上)

來源:千鋒教育
發(fā)布人:zyh
時間: 2023-06-02 09:45:00 1685670300

  操作元素樣式

  style

  ●專門用來給元素添加 css 樣式的

  ●在 JS 內(nèi)操作元素樣式style的情況分成三種

  ○設(shè)置元素的行內(nèi)樣式

  ○獲取元素行內(nèi)樣式(只能獲取到行內(nèi)樣式)

  ○獲取元素非行內(nèi)樣式(可以獲取行內(nèi)樣式也可以獲取非行內(nèi)樣式)

  ■非行內(nèi)樣式有內(nèi)嵌式和外鏈?zhǔn)?/p>

<body>
<div></div>

<script>
var div = document.querySelector('div')
div.style.width = "100px"
div.style.height = "100px"
div.style.backgroundColor = "pink"
console.log(div)
// <div style="width: 100px; height: 100px; background-color: pink;"></div>
</script>
</body>

  ●頁面中的 div 就會變成一個寬高都是 100,背景顏色是粉色

  操作元素類名

  className

  ●專門用來操作元素的 類名的

  ●實際上就是操作元素的原生屬性,只不過在js中class是一個關(guān)鍵字,所以我們操作原生屬性改用className

  獲取

  ●語法:元素對象.calssName

  ●返回值:得到的就是元素的完整類名 

<body>
<div class="box"></div>
<script>
var div = document.querySelector('div')
console.log(div.className) // box
</script>
</body>

  設(shè)置

  ●語法:元素對象.className = '值'

  ●這樣設(shè)置是全覆蓋式的操作,也就是把之前的類名會全部覆蓋掉 

<body>
<div class="box"></div>

<script>
var div = document.querySelector('div')
div.className = 'test'
console.log(div) // <div class="test"></div>
</script>
</body>

  ●在設(shè)置的時候,不管之前有沒有類名,都會全部被設(shè)置的值覆蓋

  追加

  ●語法:元素.className += ' 值'

  ●注意: 值的位置要書寫一個空格

<!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>
</head>

<body>
<div class="seal">你好 世界</div>
<script>
var box = document.querySelector('div')
box.className += ' container'
console.log(box);//<div class="seal container">你好 世界</div>
</script>
</body>

</html>

  classList

  ●每一個元素都有一個屬性叫做 classList,是一個類似數(shù)組的集合, 里面記錄了元素所有的類名

  ●classList操作類名有幾種方式:添加,刪除和切換

  添加類名

  ●語法: 元素.classList.add('要添加的類名')

  ●作用: 給該元素添加一個類名, 但是重復(fù)的不會添加進去了

<!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>
</head>

<body>
<div class="seal">你好 世界</div>
<script>
var box = document.querySelector('div')
console.log(box.classList); //['seal', value: 'seal']
box.classList.add('cls')
console.log(box);//<div class="seal cls">你好 世界</div>
</script>
</body>

</html>

  刪除類名

  ●語法: 元素.classList.remove('要刪除的類名')

  ●作用: 該該元素刪除一個類名

<!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>
</head>

<body>
<div class="seal hello">你好 世界</div>
<script>
var box = document.querySelector('div')
box.classList.remove('hello')
console.log(box); //<div class="seal">你好 世界</div>
</script>
</body>

</html>

  切換類名

  ●語法: 元素.classList.toggle('要切換的類名')

  ●作用: 該元素切換一個類名

  ●切換: 有就刪除, 沒有就添加

<!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>
</head>

<body>
<div class="seal hello">你好 世界</div>
<script>
var box = document.querySelector('div')
box.classList.toggle('hello')
box.classList.toggle('world')
console.log(box); //<div class="seal world">你好 世界</div>
</script>
</body>

</html>

  操作元素屬性

  ●元素屬性:書寫在標(biāo)簽身上, 一個 key=value 的鍵值對, 叫做一條屬性

  ●通過我們各種獲取元素的方式獲取到頁面中的標(biāo)簽以后

  ●我們可以直接操作 DOM 元素的屬性,就能直接把效果展示在頁面上

  屬性的分類

  ●原生屬性

  ○在 W3C 規(guī)范中提到的屬性, 對標(biāo)簽有一定的特殊意義或者描述作用

  ■id, class, src, type, ...

  ●自定義屬性

  ○對于標(biāo)簽沒有特殊的作用或者描述任務(wù), 只是用來在標(biāo)簽身上記錄一些信息

  ●H5 自定義屬性

  ○只是 H5 自定義屬性會以 data- 開頭, 直觀的看出來是自定義屬性

  ○設(shè)置的方式: data-屬性名=屬性值

  操作元素屬性

  ●以下的所有操作屬性的方式和方法, 均不操作 類名(class) 和 樣式(style)

  ●操作原生屬性

  ○直接依靠屬性名進行操作

  ■獲取: 元素.屬性名

  ●得到的就是該元素指定屬性的值

  ■設(shè)置: 元素.屬性名 = 屬性值

  ●作用修改該屬性的值

  ●操作自定義屬性

  ○獲取:

  ■語法: 元素.getAttribute(屬性名)

  ■返回值: 元素中該屬性對應(yīng)的值

  ○設(shè)置:

  ■語法: 元素.setAttribute(屬性名, 屬性值)

  ■作用: 設(shè)置或者修改一條自定義屬性

  ○刪除:

  ■語法: 元素.removeAttribut(屬性名)

  ■作用: 刪除元素身上該自定義屬性

  ●操作H5 自定義屬性

  ○每一個元素身上自帶一個屬性, 叫做 dataset, 是一個類似于對象的數(shù)據(jù)結(jié)構(gòu)

  ○里面記錄的是該元素身上所有的 data- 開頭的自定義屬性

  ○對于所有 H5 自定義屬性的操作依賴于這個 dataset

  ○獲取: 元素.dataset.屬性名

  ○設(shè)置: 元素.dataset.屬性名 = 屬性值

  ○刪除: delete 元素.dataset.屬性名

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<meta http-equiv="X-UA-Compatible" content="ie=edge">
<title>Document</title>
</head>
<body>

<div id="container" class="box" hello="world" data-index="1" data-id="10">123</div>
<!-- <img src="https://img2.baidu.com/it/u=2102736929,2417598652&fm=26&fmt=auto&gp=0.jpg" alt=""> -->

<script>

// 0. 獲取元素
var box = document.querySelector('div')
var img = document.querySelector('img')

// 1. 操作原生屬性
// 1-1. 原生屬性獲取
console.log(box.id)
console.log(img.src)
// 1-2. 原生屬性修改
box.id = 'abcd'
img.src = 'https://img0.baidu.com/it/u=1514002029,2035215441&fm=26&fmt=auto&gp=0.jpg'

// 2. 自定義屬性
// 2-1. 自定義屬性獲取
var res = box.getAttribute('hello')
console.log(res)
// 2-2. 自定義屬性設(shè)置
box.setAttribute('guoxiang', '你好')
box.setAttribute('guoxiang', '世界')
// 2-3. 自定義屬性刪除
box.removeAttribute('hello')

// 3. H5 自定義屬性
// 3-1. 獲取
console.log(box.dataset.index)
// 3-2. 設(shè)置
// 在標(biāo)簽上設(shè)置了一個 data-guoxiang="你好"
box.dataset.guoxiang = '你好'
box.dataset.guoxiang = '世界'
// 3-3. 刪除
delete box.dataset.index

</script>
</body>
</html>


  案例-密碼可視

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<meta http-equiv="X-UA-Compatible" content="ie=edge">
<title>Document</title>
</head>
<body>

<input type="password"><button>眼睛</button>

<script>
/*
案例 - 密碼可視
+ 當(dāng)點擊這個 眼睛 按鈕的時候
=> 判斷 input 元素的 type 屬性如果是 password 修改為 text
=> 判斷 input 元素的 type 屬性如果是 text 修改為 password
*/


// 0. 獲取元素
var inp = document.querySelector('input')
var btn = document.querySelector('button')

// 1. 給 btn 綁定點擊事件
btn.onclick = function () {
// 2. 拿到元素現(xiàn)在的 type 屬性的值
var current = inp.type

// 3. 判斷
if (current === 'password') {
// 設(shè)置為 text
inp.type = 'text'
} else {
// 設(shè)置為 password
inp.type = 'password'
}
}
</script>
</body>
</html>


tags: JavaScript
聲明:本站稿件版權(quán)均屬千鋒教育所有,未經(jīng)許可不得擅自轉(zhuǎn)載。
10年以上業(yè)內(nèi)強師集結(jié),手把手帶你蛻變精英
請您保持通訊暢通,專屬學(xué)習(xí)老師24小時內(nèi)將與您1V1溝通
免費領(lǐng)取
今日已有369人領(lǐng)取成功
劉同學(xué) 138****2860 剛剛成功領(lǐng)取
王同學(xué) 131****2015 剛剛成功領(lǐng)取
張同學(xué) 133****4652 剛剛成功領(lǐng)取
李同學(xué) 135****8607 剛剛成功領(lǐng)取
楊同學(xué) 132****5667 剛剛成功領(lǐng)取
岳同學(xué) 134****6652 剛剛成功領(lǐng)取
梁同學(xué) 157****2950 剛剛成功領(lǐng)取
劉同學(xué) 189****1015 剛剛成功領(lǐng)取
張同學(xué) 155****4678 剛剛成功領(lǐng)取
鄒同學(xué) 139****2907 剛剛成功領(lǐng)取
董同學(xué) 138****2867 剛剛成功領(lǐng)取
周同學(xué) 136****3602 剛剛成功領(lǐng)取
相關(guān)推薦HOT
PMP?認(rèn)證榮獲北京市境外職業(yè)資格認(rèn)可!

北京市人力資源和社會保障局、北京市人才工作局近日發(fā)布了關(guān)于印發(fā)《北京市境外職業(yè)資格認(rèn)可目錄(3.0版)》的通知,新版目錄境外職業(yè)資格清單...詳情>>

2023-09-07 17:27:00
怎么選擇靠譜的短視頻運營培訓(xùn)機構(gòu)?

怎么選擇靠譜的短視頻運營培訓(xùn)機構(gòu)?5G時代的來臨,短視頻作為新媒體中最為主流的內(nèi)容更加方便用戶瀏覽觀看信息,因此抖音、快手這類的短視頻平...詳情>>

2023-09-07 15:05:06
全媒體短視頻運營好就業(yè)么?

全媒體短視頻運營好就業(yè)么?現(xiàn)在學(xué)習(xí)互聯(lián)網(wǎng)運營可不能只會單個的運營技術(shù),企業(yè)更喜歡全能型人才。如今的互聯(lián)網(wǎng)世界有多種平臺,新媒體、短視頻...詳情>>

2023-09-07 14:49:25
短視頻運營培訓(xùn)機構(gòu)有用嗎?

短視頻運營培訓(xùn)機構(gòu)有用嗎?短視頻的火熱,催生了一大批的網(wǎng)絡(luò)紅人、網(wǎng)紅賬號,這些短視頻賬號通過實現(xiàn)粉絲流量變現(xiàn),獲得了非常豐厚的收入,自...詳情>>

2023-09-06 13:49:12
大數(shù)據(jù)分析就業(yè)高薪崗位介紹

大數(shù)據(jù)分析就業(yè)高薪崗位介紹?大數(shù)據(jù)行業(yè)是一個快速發(fā)展的行業(yè),其主要特征是數(shù)據(jù)規(guī)模龐大、種類多樣、處理復(fù)雜。目前,大數(shù)據(jù)行業(yè)已經(jīng)成為全球...詳情>>

2023-09-06 13:42:47
開班信息
北京校區(qū)
  • 北京校區(qū)
  • 大連校區(qū)
  • 廣州校區(qū)
  • 成都校區(qū)
  • 杭州校區(qū)
  • 長沙校區(qū)
  • 合肥校區(qū)
  • 南京校區(qū)
  • 上海校區(qū)
  • 深圳校區(qū)
  • 武漢校區(qū)
  • 鄭州校區(qū)
  • 西安校區(qū)
  • 青島校區(qū)
  • 重慶校區(qū)
  • 太原校區(qū)
  • 沈陽校區(qū)
  • 南昌校區(qū)
  • 哈爾濱校區(qū)