日韩久久久精品,亚洲精品久久久久久久久久久,亚洲欧美一区二区三区国产精品 ,一区二区福利

冷門Javascript API——element.insertAdjacent

系統 4318 0

John Resig(jQuery的作者)在2008年的時候曾經嘗試將elment.insertAdjacentHTML引入jQuery,不過他最終放棄了。主要原因在于:

  • 其在IE6中不支持向table,tbody,thead或者tr插入html,否則會拋出錯誤。
  • 不支持XML文檔。

不過當時,這一由IE4.0開始出現的接口已經進入了HTML5的接口名單,將會有更多瀏覽器實現該接口,下面便是目前桌面瀏覽器的支持情況:

?

Feature Chrome Firefox (Gecko) Internet Explorer Opera Safari (WebKit)
Basic support 1.0 8.0 (8.0) 4.0 7.0 4.0 (527)

?

但是,我們為什么會關注這一接口呢?

?

比element.innerHTML更好的性能

測試結果表明,element.insertAdjacentHTML在大部分情況下有比element.innerHTML更好的性能:

http://jsperf.com/insertadjacenthtml-perf/4

這可能是比Document Fragments更好的HTML文檔插入方案,因為我們知道Document Fragments在某些IE版本中的表現比較糟糕(看來IE的實現方式和別的都不太一樣啊……)。

這給我們得模板優化提供了可行而簡易的方案。

好吧,那element.insertAdjacentHTML這接口怎么用呢?

?

在指定位置插入HTML

element.insertAdjancentHTML(position, html)

需要傳入字符串參數position,以及字符串參數html代碼。我們可以對照jQuery的HTML插入方法,得到這一position的對照關系:

.insertAdjacentHTML("beforeBegin", ...) ?—— ?before

.insertAdjacentHTML("afterBegin", ...) ?—— ?prepend

.insertAdjacentHTML("beforeEnd", ...) ?—— ?append

.insertAdjacentHTML("afterEnd", ...) ?—— ?after

即:

beforeBegin:在該元素前插入

afterBegin:在該元素第一個子元素前插入

beforeEnd:在該元素最后一個子元素后面插入

afterEnd:在該元素后插入

?不過,當元素是空的時候,其和innerHTML就可以很相像了,比如:

      
        var
      
       menu = document.createElment("div"
      
        );
menu.insertAdjacentHTML(
      
      "afterEnd"
      
        ,
    
      
      "<p>Hello world!</p>");
    

這里就和menu.innerHTML('<p>Hello world!</p>')是一樣的。

?

總結?

主要還是看需求。由于我們的項目可以不考慮IE6,所以IE6的問題就不是問題了。而且模板引擎不會插入XML Document,所以第二個問題也不是問題了。

?

參考資料

DOM insertAdjacentHTML ?.?John Resig

element.insertAdjacentHTML ?. MDN

?

冷門Javascript API——element.insertAdjacentHTML


更多文章、技術交流、商務合作、聯系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號聯系: 360901061

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。

【本文對您有幫助就好】

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長會非常 感謝您的哦!!!

發表我的評論
最新評論 總共0條評論
主站蜘蛛池模板: 治多县| 新蔡县| 定结县| 阳曲县| 张家界市| 革吉县| 万盛区| 盈江县| 沁阳市| 永新县| 河北省| 东城区| 西乌| 闽清县| 东丽区| 闸北区| 罗甸县| 前郭尔| 黄浦区| 长岛县| 祁连县| 江华| 财经| 牙克石市| 崇州市| 汪清县| 手游| 岳普湖县| 巴林左旗| 万源市| 合山市| 潮安县| 新营市| 巴林右旗| 太原市| 老河口市| 辰溪县| 平阳县| 临漳县| 万宁市| 乐亭县|