JavaScript 屬性的操作

2018-07-24 11:52 更新

目錄

HTML元素包括標(biāo)簽名和若干個鍵值對,這個鍵值對就稱為“屬性”(attribute)。

<a id="test" href="http://www.example.com">
  鏈接
</a>

上面代碼中,a元素包括兩個屬性:id屬性和href屬性。

在DOM中,屬性本身是一個對象(Attr對象),但是實際上,這個對象極少使用。一般都是通過元素節(jié)點對象(HTMlElement對象)來操作屬性。本節(jié)介紹如何操作這些屬性。

Element.attributes屬性

HTML元素對象有一個attributes屬性,返回一個類似數(shù)組的動態(tài)對象,成員是該元素標(biāo)簽的所有屬性節(jié)點對象,屬性的實時變化都會反映在這個節(jié)點對象上。其他類型的節(jié)點對象,雖然也有attributes屬性,但是返回的都是null,因此可以把這個屬性視為元素對象獨有的。

document.body.attributes[0]
document.body.attributes.bgcolor
document.body.attributes['ONLOAD']

注意,上面代碼中,第一行attributes[0]返回的是屬性節(jié)點對象,后兩行都返回屬性值。

屬性節(jié)點對象有namevalue屬性,對應(yīng)該屬性的屬性名和屬性值,等同于nodeName屬性和nodeValue屬性。

// HTML代碼為
// <div id="mydiv">
var n = document.getElementById('mydiv');

n.attributes[0].name // "id"
n.attributes[0].nodeName // "id"

n.attributes[0].value // "mydiv"
n.attributes[0].nodeValue // "mydiv"

下面代碼可以遍歷一個元素節(jié)點的所有屬性。

var para = document.getElementsByTagName('p')[0];

if (para.hasAttributes()) {
  var attrs = para.attributes;
  var output = '';
  for(var i = attrs.length - 1; i >= 0; i--) {
    output += attrs[i].name + '->' + attrs[i].value;
  }
  result.value = output;
} else {
  result.value = 'No attributes to show';
}

元素節(jié)點對象的屬性

HTML元素節(jié)點的標(biāo)準(zhǔn)屬性(即在標(biāo)準(zhǔn)中定義的屬性),會自動成為元素節(jié)點對象的屬性。

var a = document.getElementById('test');
a.id // "test"
a.href // "http://www.example.com/"

上面代碼中,a元素標(biāo)簽的屬性idhref,自動成為節(jié)點對象的屬性。

這些屬性都是可寫的。

var img = document.getElementById('myImage');
img.src = 'http://www.example.com/image.jpg';

上面的寫法,會立刻替換掉img對象的src屬性,即會顯示另外一張圖片。

這樣修改HTML屬性,常常用于添加表單的屬性。

var f = document.forms[0];
f.action = 'submit.php';
f.method = 'POST';

上面代碼為表單添加提交網(wǎng)址和提交方法。

注意,這種用法雖然可以讀寫HTML屬性,但是無法刪除屬性,delete運算符在這里不會生效。

HTML元素的屬性名是大小寫不敏感的,但是JavaScript對象的屬性名是大小寫敏感的。轉(zhuǎn)換規(guī)則是,轉(zhuǎn)為JavaScript屬性名時,一律采用小寫。如果屬性名包括多個單詞,則采用駱駝拼寫法,即從第二個單詞開始,每個單詞的首字母采用大寫,比如onClick。

有些HTML屬性名是JavaScript的保留字,轉(zhuǎn)為JavaScript屬性時,必須改名。主要是以下兩個。

  • for屬性改為htmlFor
  • class屬性改為className

另外,HTML屬性值一般都是字符串,但是JavaScript屬性會自動轉(zhuǎn)換類型。比如,將字符串true轉(zhuǎn)為布爾值,將onClick的值轉(zhuǎn)為一個函數(shù),將style屬性的值轉(zhuǎn)為一個CSSStyleDeclaration對象。

屬性操作的標(biāo)準(zhǔn)方法

概述

元素節(jié)點提供四個方法,用來操作屬性。

  • getAttribute()
  • setAttribute()
  • hasAttribute()
  • removeAttribute()

其中,前兩個讀寫屬性的方法,與前一部分HTML標(biāo)簽對象的屬性讀寫,有三點差異。

(1)適用性

getAttribute()setAttribute()對所有屬性(包括用戶自定義的屬性)都適用;HTML標(biāo)簽對象的屬性,只適用于標(biāo)準(zhǔn)屬性。

(2)返回值

getAttribute()只返回字符串,不會返回其他類型的值。HTML標(biāo)簽對象的屬性會返回各種類型的值,包括字符串、數(shù)值、布爾值或?qū)ο蟆?/p>

(3)屬性名

這些方法只接受屬性的標(biāo)準(zhǔn)名稱,不用改寫保留字,比如forclass都可以直接使用。另外,這些方法對于屬性名是大小寫不敏感的。

var image = document.images[0];
image.setAttribute('class', 'myImage');

上面代碼中,setAttribute方法直接使用class作為屬性名,不用寫成className。

Element.getAttribute()

Element.getAttribute方法返回當(dāng)前元素節(jié)點的指定屬性。如果指定屬性不存在,則返回null。

// HTML代碼為
// <div id="div1" align="left">
var div = document.getElementById('div1');
div.getAttribute('align') // "left"

Element.setAttribute()

Element.setAttribute方法用于為當(dāng)前元素節(jié)點新增屬性。如果同名屬性已存在,則相當(dāng)于編輯已存在的屬性。

var d = document.getElementById('d1');
d.setAttribute('align', 'center');

下面是對img元素的src屬性賦值的例子。

var myImage = document.querySelector('img');
myImage.setAttribute('src', 'path/to/example.png');

Element.hasAttribute()

Element.hasAttribute方法返回一個布爾值,表示當(dāng)前元素節(jié)點是否包含指定屬性。

var d = document.getElementById('div1');

if (d.hasAttribute('align')) {
  d.setAttribute('align', 'center');
}

上面代碼檢查div節(jié)點是否含有align屬性。如果有,則設(shè)置為“居中對齊”。

Element.removeAttribute()

Element.removeAttribute方法用于從當(dāng)前元素節(jié)點移除屬性。

// HTML代碼為
// <div id="div1" align="left" width="200px">
document.getElementById('div1').removeAttribute('align');
// 現(xiàn)在的HTML代碼為
// <div id="div1" width="200px">

dataset屬性

有時,需要在HTML元素上附加數(shù)據(jù),供JavaScript腳本使用。一種解決方法是自定義屬性。

<div id="mydiv" foo="bar">

上面代碼為div元素自定義了foo屬性,然后可以用getAttribute()setAttribute()讀寫這個屬性。

var n = document.getElementById('mydiv');
n.getAttribute('foo') // bar
n.setAttribute('foo', 'baz')

這種方法雖然可以達(dá)到目的,但是會使得HTML元素的屬性不符合標(biāo)準(zhǔn),導(dǎo)致網(wǎng)頁的HTML代碼通不過校驗。

更好的解決方法是,使用標(biāo)準(zhǔn)提供的data-*屬性。

<div id="mydiv" data-foo="bar">

然后,使用元素節(jié)點對象的dataset屬性,它指向一個對象,可以用來操作HTML元素標(biāo)簽的data-*屬性。

var n = document.getElementById('mydiv');
n.dataset.foo // bar
n.dataset.foo = 'baz'

上面代碼中,通過dataset.foo讀寫data-foo屬性。

刪除一個data-*屬性,可以直接使用delete命令。

delete document.getElementById('myDiv').dataset.foo;

除了dataset屬性,也可以用getAttribute('data-foo')、removeAttribute('data-foo')、setAttribute('data-foo')hasAttribute('data-foo')等方法操作data-*屬性。

注意,data-后面的屬性名有限制,只能包含字母、數(shù)字、連詞線(-)、點(.)、冒號(:)和下劃線(_)。而且,屬性名不應(yīng)該使用AZ的大寫字母,比如不能有data-helloWorld這樣的屬性名,而要寫成data-hello-world。

轉(zhuǎn)成dataset的鍵名時,連詞線后面如果跟著一個小寫字母,那么連詞線會被移除,該小寫字母轉(zhuǎn)為大寫字母,其他字符不變。反過來,dataset的鍵名轉(zhuǎn)成屬性名時,所有大寫字母都會被轉(zhuǎn)成連詞線+該字母的小寫形式,其他字符不變。比如,dataset.helloWorld會轉(zhuǎn)成data-hello-world

以上內(nèi)容是否對您有幫助:
在線筆記
App下載
App下載

掃描二維碼

下載編程獅App

公眾號
微信公眾號

編程獅公眾號