摘要:從學習前端以來,屬性和特性已困惑我很久。注意啦,屬性和特性的一個關系出現了。以下除外屬性表明節點的類型。與之前了解到的特性用來描述屬性的行為并無出入。下面,我們一起來看看屬性和特性是如何訪問的。操作特性的方法主要有三個,分別是和。
從學習前端以來,屬性和特性已困惑我很久。今天使用jQuery時,又踩到了這個坑。于是下定決心,徹底搞懂它。
一、對象、屬性和特性的關系先來看一下詞典的解釋:
property:1、財產、所有權、房地產;2、性質、特性、屬性;
attribute:屬性、特質、特性、品質
好吧,除了財產、房地產(手動斜眼),好像不能把他倆區分開來。既然如此,我還是從專業書籍中尋找答案吧。《JavaScript高級程序設計》第6章:
ECMA-262把對象定義為:“無序屬性的集合,其屬性可以包含基本值、對象或者函數”。
“嗯...對象..的屬性..”
好像與對象有直接的聯系!property不是財產嗎?那我假裝property就是object的財產好了(手動滑稽)。
來個例子吧:
var person = { name: “小明”, age: ‘26’, sayName: function(){ alert(this.name); } };
這里,name和age都是person對象的屬性。
這些屬性在創建時都帶有一些特征值(characteristic), JavaScript 通過這些特征值來定義它們的行為。--《JavaScript高級程序設計》
簡單點說,屬性有特征值,用來定義屬性的行為。(注意啦,屬性和特性的一個關系出現了。)對于像name和age這樣的屬性,有4個特性描述它們的行為,分別是[[Configurable]]、[[Enumerable]]、[[Writable]]、[[Value]],這些特性描述了name和age屬性:
1、是否可以重新定義
2、是否可以用for-in循環返回屬性
3、是否可以修改
好的,我們到這里先打住,我們知道了,特性可以用來描述屬性的行為。
這里,我們自己創建的一個對象和DOM對象從直觀上來看,好像不太一樣。兩者不太容易產生聯系。那么,讓我們把目光聚焦到DOM(文檔對象模型)上吧,它可是如假包換的對象啊!
JavaScript 中的所有節點類型都繼承自 Node 類型,因此所有節點類型都共享著相同的基本屬性和方法。(IE9以下除外)
nodetype屬性:表明節點的類型。值為1表示節點是Element類型,2是Attr類型,3是Text類型,等等
nodeName屬性:節點名稱
nodeValue屬性:節點值
...
也就是說,我們html中的div、ul、li等等都是node節點,而像id、class、type、title等是元素節點的特性,特性屬于Attr類型,而特性是元素attributes屬性的節點。
看起來很繞,我們試著捋一捋,像div這樣的元素,它有attributes屬性,而id、class等是該屬性的節點,也就是說,id和class這樣的特性是用來描述attributes屬性的。與之前了解到的“特性用來描述屬性的行為”并無出入。
到這里,我們小結一下。不論是person對象還是DOM對象(比如div),它們都有自己的屬性(property),而屬性又有一個叫特性(attribute)的東西來定義它的行為。好的,我們弄明白這三者的關系了。
但是,我們似乎還有一些謎團沒有解開。下面,我們一起來看看屬性和特性是如何訪問的。
二、屬性和特性的訪問要訪問對象的屬性,例如剛剛的person對象,我們可以用person.name來訪問person對象的name屬性;對于DOM對象,為了說清楚問題,我們先獲取對象的引用:
var oBox = document.getElementById("box"); //我們可以通過oBox.tagName訪問tagName屬性和nodeType屬性 console.log(oBox.tagName); //DIV console.log(oBox.nodeType); //1
可是,這很正常啊!問題出現在:
//我們可以通過oBox.id獲取對象的id值 console.log(oBox.id); //box console.log(oBox.className); //red
可能我們會覺得,這依然很正常啊!哪里不對嗎?
是的,這里不正常!因為id明明是oBox對象的attributes屬性中的節點,它又不是屬性,憑啥可以用oBox.id來訪問?!可是我們當初就是這么學的呀,一開始就是這么使用的啊~
崩潰后,我們找到了答案,來自《JavaScript高級程序設計》:
所有HTML元素都由HTMLElement類型表示,HTMLElement類型直接繼承自Element并添加了一些屬性。添加的這些屬性分別對應于每個HTML元素中都存在的下列標準特性:id、className、title等
啊,恍然大悟!快哉~
之所以能夠這么訪問,原來是設計者的良苦用心啊,把id、class、title這樣的特性添加為html element的屬性id、className、title,這么訪問不就方便了嗎?
到這里,迷霧已經散去。我們漸漸看到了真相。
每個元素都有一或多個特性,這些特性的用途是給出相應元素或其內容的附加信息。操作特性的
DOM 方法主要有三個,分別是 getAttribute()、 setAttribute()和 removeAttribute()。這三
個方法可以針對任何特性使用,包括那些以 HTMLElement 類型屬性的形式定義的特性。
console.log(oBox.getAttribute("id")); //box console.log(oBox.getAttribute("class")); //red
這樣,我們也明白了,為什么用getAttribute()訪問class時,不需要用className的原因。
三、自定義特性和屬性 1.自定義特性html:
js:
oBox.setAttribute("left","left");
不過,自定義的特性不能用屬性的方式來訪問,
console.log(oBox.left); //undefined console.log(oBox.getAttribute("left")); //left
另外,HTML5規范中,自定義特性應該加上data-前綴,以便驗證。
2.自定義屬性其實,我們有用過“自定義”屬性,在設置定時器時,將timer綁定在元素上,不同的元素就有自己的定時器了。
oBox.timer = setTimeout(function(){ //to do },5000); oBox2.timer = setTimeout(function(){ //to do 2 },5000);
(完)
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://specialneedsforspecialkids.com/yun/51650.html
摘要:從學習前端以來,屬性和特性已困惑我很久。注意啦,屬性和特性的一個關系出現了。以下除外屬性表明節點的類型。與之前了解到的特性用來描述屬性的行為并無出入。下面,我們一起來看看屬性和特性是如何訪問的。操作特性的方法主要有三個,分別是和。 從學習前端以來,屬性和特性已困惑我很久。今天使用jQuery時,又踩到了這個坑。于是下定決心,徹底搞懂它。 一、對象、屬性和特性的關系 先來看一下詞典的解釋...
摘要:如果還有人問你兩者區別,馬上甩出這種圖有興趣可以往下閱讀,官方手冊給出的例子手冊這是一張將區別的表格,從表格中我們可以發現返回值等同返回值等同。 簡單談一下isset和empty的區別? 如果你是在面試,碰巧面試官提了這個問題。你可以這樣回答: 如果變量值為0、空字符串、空數組等等,empty認為它是空的,而isset認為它不是空的。 如果變量不存在,isset和empty都認為它是...
摘要:圖對可復用代碼挑戰最大的五項問題五大開發問題如下。瀏覽器的缺陷修復。瀏覽器缺失的功能。復雜的地方是,當前瀏覽器會在未來的瀏覽器版本中被修復。假設瀏覽器引起常見的網站問題為解決瀏覽器使用特殊技巧,將來瀏覽器發布新版本修復了,就會出現問題。 任意一段重要的代碼都需要關注無數的開發問題。但是,其中對可復用JavaScript代碼挑戰最大的五項問題如圖14.2所示。 showImg(https...
摘要:如圖使用事件捕獲模式注冊事件監聽對最外層,中間層,最內層分別用捕獲模式注冊事件監聽,我們上面說了,如果使用捕獲模式,那么第三個參數應該是,否則則是冒泡模式,如果不聲明,默認為冒泡模式。 來源: 個人博客 想必好多童鞋都有直接復制粘貼event.preventDefault() 或者event.stopPropagation() 的經歷,但是為什么這樣做不甚了解,今天我們的目的就是要徹...
閱讀 2029·2021-11-08 13:14
閱讀 2939·2021-10-18 13:34
閱讀 2027·2021-09-23 11:21
閱讀 3589·2019-08-30 15:54
閱讀 1758·2019-08-30 15:54
閱讀 2929·2019-08-29 15:33
閱讀 2578·2019-08-29 14:01
閱讀 1945·2019-08-29 13:52