DOM對(duì)象是什么時(shí)候被創(chuàng)建的

我本來想想練習(xí)一個(gè)小范例:

頁面上寫一個(gè)文本輸入框和一個(gè)按鈕侣滩,點(diǎn)擊按鈕讓文本框禁用证逻,不可再輸入。

思路是這樣: 先獲取到文本框?qū)ο笳殷荩o按鈕設(shè)置一個(gè)點(diǎn)擊事件,點(diǎn)擊時(shí)將文本框的disabled屬性修改為“True”慷吊,從而讓文本框禁用袖裕。

我寫的代碼是這樣:

<html>
<head>
    <meta charset="utf-8">
    <title>獲取input并禁用</title>
    <script type="text/javascript">
        var txt = document.getElementById('txt');
        function fobbiden(){
            txt.disabled = true;
        }
    </script>
</head>
<body>
    <input type="text" id="txt">
    <input type="button" onclick="fobbiden()" value="禁用" id="btn">
</body>
</html>

然而,實(shí)際運(yùn)行的時(shí)候溉瓶,點(diǎn)擊按鈕并沒有讓文本框禁用急鳄,審查元素調(diào)試一下谤民,提示

Uncaught TypeError: Cannot set property 'disabled' of null
at fobbiden (獲取input并禁用.html:10)
at HTMLInputElement.onclick (獲取input并禁用.html:16)

大概是說,在執(zhí)行onclick事件的fobbiden函數(shù)時(shí)攒岛,disabled作為null沒辦法設(shè)置屬性赖临。

思考了一下胞锰,推測(cè)可能是因?yàn)?/p>

var txt = document.getElementById('txt');

執(zhí)行的時(shí)候灾锯,還沒有“txt”這個(gè)DOM對(duì)象。于是嗅榕,我把這句拿到函數(shù)里來顺饮,當(dāng)觸發(fā)onclick事件的時(shí)候,再通過getElementById去獲取txt對(duì)象凌那。代碼如下:

<html>
<head>
    <meta charset="utf-8">
    <title>獲取input并禁用</title>
    <script type="text/javascript">     
        function fobbiden(){
            var txt = document.getElementById('txt');
            txt.disabled = true;
        }
    </script>
</head>
<body>
    <input type="text" id="txt">
    <input type="button" onclick="fobbiden()" value="禁用" id="btn">
</body>
</html>

打開瀏覽器試一下兼雄,果然可以。

那么問題來了帽蝶,DOM對(duì)象是在什么時(shí)候創(chuàng)建的呢赦肋?

不太懂這方面較低層的知識(shí),但是可以推測(cè)励稳,如果瀏覽器是按照節(jié)點(diǎn)樹的順序來渲染的話佃乘,最快的情況也就是,當(dāng)這個(gè)節(jié)點(diǎn)被創(chuàng)建的同時(shí)驹尼,DOM對(duì)象就存在了趣避。

201701.jpg

試一下代碼:

<html>
<head>
    <meta charset="utf-8">
    <title>獲取input并禁用</title>
</head>
<body>
    <input type="text" id="txt">
    <script type="text/javascript">
        var txt = document.getElementById('txt');
        console.log(txt);
    </script>
    <input type="button" onclick="fobbiden()" value="禁用" id="btn">
    <script type="text/javascript">
        var btn = document.getElementById('btn');   
        btn.onclick = function(){
            txt.disabled = true;
        }
    </script>
</body>
</html>

我在第一個(gè)<input>標(biāo)簽后馬上寫了兩句:

var txt = document.getElementById('txt');
console.log(txt);

最后測(cè)試的結(jié)果正確,說明此時(shí)已經(jīng)可以獲取“txt”DOM對(duì)象新翎,并且通過console.log()打印的結(jié)果如下:

微信截圖_20180424220035.png

同樣驗(yàn)證了結(jié)果程帕。

至此,我們可以認(rèn)為地啰,當(dāng)瀏覽器通過html標(biāo)簽渲染出一個(gè)節(jié)點(diǎn)愁拭,同時(shí)也創(chuàng)建了DOM對(duì)象,此時(shí)即可以通過javascript的方法去獲取這個(gè)DOM對(duì)象亏吝。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末敛苇,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子顺呕,更是在濱河造成了極大的恐慌枫攀,老刑警劉巖,帶你破解...
    沈念sama閱讀 218,546評(píng)論 6 507
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件株茶,死亡現(xiàn)場(chǎng)離奇詭異来涨,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)启盛,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,224評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門蹦掐,熙熙樓的掌柜王于貴愁眉苦臉地迎上來技羔,“玉大人,你說我怎么就攤上這事卧抗√倮模” “怎么了?”我有些...
    開封第一講書人閱讀 164,911評(píng)論 0 354
  • 文/不壞的土叔 我叫張陵社裆,是天一觀的道長拙绊。 經(jīng)常有香客問我,道長泳秀,這世上最難降的妖魔是什么标沪? 我笑而不...
    開封第一講書人閱讀 58,737評(píng)論 1 294
  • 正文 為了忘掉前任,我火速辦了婚禮嗜傅,結(jié)果婚禮上金句,老公的妹妹穿的比我還像新娘。我一直安慰自己吕嘀,他們只是感情好违寞,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,753評(píng)論 6 392
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著偶房,像睡著了一般趁曼。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上蝴悉,一...
    開封第一講書人閱讀 51,598評(píng)論 1 305
  • 那天彰阴,我揣著相機(jī)與錄音,去河邊找鬼拍冠。 笑死尿这,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的庆杜。 我是一名探鬼主播射众,決...
    沈念sama閱讀 40,338評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼晃财!你這毒婦竟也來了叨橱?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,249評(píng)論 0 276
  • 序言:老撾萬榮一對(duì)情侶失蹤断盛,失蹤者是張志新(化名)和其女友劉穎罗洗,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體钢猛,經(jīng)...
    沈念sama閱讀 45,696評(píng)論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡伙菜,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,888評(píng)論 3 336
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了命迈。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片贩绕。...
    茶點(diǎn)故事閱讀 40,013評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡火的,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出淑倾,到底是詐尸還是另有隱情馏鹤,我是刑警寧澤,帶...
    沈念sama閱讀 35,731評(píng)論 5 346
  • 正文 年R本政府宣布娇哆,位于F島的核電站湃累,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏迂尝。R本人自食惡果不足惜脱茉,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,348評(píng)論 3 330
  • 文/蒙蒙 一剪芥、第九天 我趴在偏房一處隱蔽的房頂上張望垄开。 院中可真熱鬧,春花似錦税肪、人聲如沸溉躲。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,929評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽锻梳。三九已至,卻和暖如春净捅,著一層夾襖步出監(jiān)牢的瞬間疑枯,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,048評(píng)論 1 270
  • 我被黑心中介騙來泰國打工蛔六, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留荆永,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 48,203評(píng)論 3 370
  • 正文 我出身青樓国章,卻偏偏與公主長得像具钥,于是被迫代替她去往敵國和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子液兽,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,960評(píng)論 2 355

推薦閱讀更多精彩內(nèi)容

  • 單例模式 適用場(chǎng)景:可能會(huì)在場(chǎng)景中使用到對(duì)象骂删,但只有一個(gè)實(shí)例,加載時(shí)并不主動(dòng)創(chuàng)建四啰,需要時(shí)才創(chuàng)建 最常見的單例模式宁玫,...
    Obeing閱讀 2,073評(píng)論 1 10
  • ??JavaScript 最初的一個(gè)應(yīng)用欧瘪,就是分擔(dān)服務(wù)器處理表單的責(zé)任,打破處處依賴服務(wù)器的局面敦迄。 ??盡管目前的...
    霜天曉閱讀 668評(píng)論 0 3
  • 工廠模式類似于現(xiàn)實(shí)生活中的工廠可以產(chǎn)生大量相似的商品恋追,去做同樣的事情凭迹,實(shí)現(xiàn)同樣的效果;這時(shí)候需要使用工廠模式。簡單...
    舟漁行舟閱讀 7,763評(píng)論 2 17
  • 歡迎關(guān)注個(gè)人微信公眾賬號(hào):byodian個(gè)人博客:Byodian's Blog JavaScript 基礎(chǔ)知識(shí)總結(jié)...
    工具速遞閱讀 760評(píng)論 0 3
  • 最近在學(xué)習(xí)javascript關(guān)于DOM的一些知識(shí)苦囱,在這里對(duì)DOM做一些總結(jié)嗅绸。 1.DOM簡介 DOM是W3C的標(biāo)...
    風(fēng)之郁少閱讀 373評(píng)論 0 5