麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 編程 > JavaScript > 正文

JavaScript中DOM詳解

2019-11-20 12:42:39
字體:
供稿:網(wǎng)友

為了達(dá)到平穩(wěn)退化,向后兼容,標(biāo)記分離的思想,每次寫js代碼時(shí)做的第一件事應(yīng)該是必要的測試和檢查工作:
在js文件里首先添加以下代碼進(jìn)行檢查:

window.onload = function(){if(!document.getElementsByTagName)  return false;if(!document.getElementById) return false;if(!document.getElementsByClassName)  return false;if(!document.getElementById("selector"))  return false;if(!document.getElementsByTagName("tag"))  return false;if(!document.getElementsByClassName("selector"))  return false;};

通用封裝函數(shù):

var $ = function(id){   return document.getElementBy Id (id);}var addEvent = function(obj,event,fn){  //obj:元素對象名字,event:綁定事件,fn:觸發(fā)的回調(diào)函數(shù)   if(obj.addEventListener){obj.addEventListener(event,fn,false);   }   else if(obj.attachEvent){obj.attachEvent("on"+event,fn);   }}

對于很多函數(shù)需要頁面加載即運(yùn)行,window.onload封裝方法如下:

function addLoadEvent(func){var oldonload = window.onload;if(typeof window.onload != "function"){window.onload = func;}else{window.onload = function(){oldonload();func();}}}addLoadEvent(firstFunction);addLoadEvent(secondFunction);

火狐和IE之間的JavaScript差異

1、在大多數(shù)情況下,為事件處理函數(shù)返回false,可以防止默認(rèn)的事件行為.例如,默認(rèn)情況下點(diǎn)擊一個(gè)a元素,頁面會跳轉(zhuǎn)到該元素href屬性指定的頁。
return false 就相當(dāng)于終止符,return true 就相當(dāng)于執(zhí)行符。
在js中對于return用法的三種景象的總結(jié)如下:
retrun true; 返回正確的處理懲罰成果。
return false;返回錯(cuò)誤的處理懲罰成果;終止處理懲罰;阻攔提交表單;阻攔履行默認(rèn)的行動。
return;把把握權(quán)返回給頁面。

2、在絕大多數(shù)時(shí)候,把一個(gè)函數(shù)調(diào)用賦值給一個(gè)變量將是一個(gè)好主意。

3、noscript標(biāo)簽可被用于可識別 script標(biāo)簽但無法支持其中的腳本的瀏覽器。如果瀏覽器支持腳本,那么它不會顯示出 noscript 標(biāo)簽中的文本。

4、在動態(tài)設(shè)置樣式時(shí),只要有可能,最好選用CSS,最簡單的就是選擇最容易實(shí)現(xiàn)的方法。

5、在一個(gè)函數(shù)中會用到全局對象存儲為局部變量來減少全局查找,因?yàn)樵L問局部變量的速度要比訪問全局變量的速度更快些。

6、如果針對的是不斷運(yùn)行的代碼,不應(yīng)該使用setTimeout,而應(yīng)該是用setInterval,因?yàn)閟etTimeout每一次都會初始化一個(gè)定時(shí)器,而setInterval只會在開始的時(shí)候初始化一個(gè)定時(shí)器。

7、如果要連接多個(gè)字符串,應(yīng)該少使用+= ,條件分支時(shí)盡量使用三目運(yùn)算符替代條件分支。

8、很多人喜歡使用parseInt(),其實(shí)parseInt()是用于將字符串轉(zhuǎn)換成數(shù)字,而不是浮點(diǎn)數(shù)和整型之間的轉(zhuǎn)換,我們應(yīng)該使用Math.floor()或者M(jìn)ath.round()。

9、在JavaScript中所有變量都可以使用單個(gè)var語句來聲明,這樣就是組合在一起的語句,以減少整個(gè)腳本的執(zhí)行時(shí)間。

10、對于大的DOM更改,使用innerHTML要比使用標(biāo)準(zhǔn)的DOM方法創(chuàng)建同樣的DOM結(jié)構(gòu)快得多。

11、當(dāng)同一個(gè)對象使用.onclick的寫法觸發(fā)多個(gè)方法的時(shí)候,后一個(gè)方法會把前一個(gè)方法覆蓋掉,也就是說,在對象的onclick事件發(fā)生時(shí),只會執(zhí)行最后綁定的方法。而用事件監(jiān)聽則不會有覆蓋的現(xiàn)象,每個(gè)綁定的事件都會被執(zhí)行。

12、如果定義了toString()方法來進(jìn)行類型轉(zhuǎn)換的話,推薦顯式調(diào)用toString(),因?yàn)閮?nèi)部的操作在嘗試所有可能性之后,會嘗試對象的toString()方法嘗試能否轉(zhuǎn)化為String,所以直接調(diào)用這個(gè)方法效率會更高。

13、因?yàn)閑lemet.style只能獲取內(nèi)聯(lián)樣式,而element.currentStyle.width是IE瀏覽器專有屬性,getComputedStyle(element, null).width是火狐和Chrome瀏覽器的特有屬性,所以為了兼容,獲取內(nèi)外樣式方法如下(不可取復(fù)合樣式,如background,border,而是應(yīng)該寫成backgroundColor,borderWidth):

function getStyle(obj,name) {   if(obj.currentStyle) {     return obj.currentStyle[name];   }   else   {     return getComputedStyle(obj,null)[name];   }}

以上所述就是本文的全部內(nèi)容了,希望大家能夠喜歡。

發(fā)表評論 共有條評論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 午夜视频在线免费观看 | 欧美性生活视频免费看 | 国产午夜精品一区二区三区不卡 | 高清国产午夜精品久久久久久 | 九草在线视频 | arabxxxxvideos| 中文字幕在线成人 | 中日韩免费视频 | 久草在线综合网 | 成人做爰高潮片免费视频韩国 | 日本aaaa片毛片免费观看视频 | 中午字幕无线码一区2020 | 国产精品麻豆一区二区三区 | 国内精品久久久久久2021浪潮 | 欧美日韩国产成人在线观看 | 久久精品视频16 | 国产一级在线观看视频 | 欧洲精品久久久久69精品 | 精品在线一区二区三区 | 双性帝王调教跪撅打屁股 | 深夜视频在线 | 亚洲九九色 | 在线亚洲播放 | 成人午夜免费av | 国产日韩一区二区三区在线观看 | 成人一区二区在线观看视频 | 久久精品一级片 | 久久久中 | www视频免费观看 | 日韩精品久久久久久 | 黄色av免费电影 | 午夜爽爽爽男女免费观看hd | 成年人性视频 | 天天操天天骑 | 免费男女乱淫真视频 | 福利在线小视频 | 一级免费黄色 | 成人午夜天堂 | 免费激情网站 | 久久草在线视频免费 | 亚洲一区二区三区在线免费观看 |