欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

javascript之querySelector和querySelectorAll使用說明

 更新時間:2011年10月09日 00:09:44   作者:  
其實關于querySelector和querySelectorAll的介紹說明很多,在此主要是做個記錄
一開始很多人都會拿jquery的選擇器來跟這兩個api做對比(我也是),比較異同本來沒事,但卻使一些同學對這兩個api在瀏覽器中的實現(xiàn)產(chǎn)生了誤解,特別是再dom element上調(diào)用此api時。

下面是我的jsFiddle示例,我就以此展開說明:
復制代碼 代碼如下:

(function(global) {
global.doc = document;
global.body = doc.getElementsByTagName('body')[0];
global.$ = function(id) {
return doc.getElementById(id);
}

global.Logger = function(id) {
this.logElem = $(id);
this.logArr = [];
};
global.Logger.prototype = {
constructor: global.logger,

append: function(comment) {
this.logArr.push('<p>' + comment + '</p>');
},

flush: function() {
this.logElem.innerHTML = this.logArr.join('');
},

clear: function() {
this.logElem.innerHTML = '';
this.logArr = [];
}
};
})(this);

(function() {
var logger = new Logger('log');

var items = $('inner').querySelectorAll('#main h4.inside');
logger.append(items.length);

for(var i = 0, len = items.length; i < len; i++) {
logger.append(items[i].innerHTML);
}

logger.flush();
})();

誤解就在于對$('inner').querySelectorAll('#main h4.inside')的實現(xiàn)理解,不少人一開始幾乎都認為是直接從div[id='inner']的孩子中進行查找(我也是),這個#main有點礙眼。實際上它還是根據(jù)selector string從整個document上查找,再返回屬于div[id='inner']的子節(jié)點。很多人會疑惑,那么為什么不按照直接按父節(jié)點找子節(jié)點的方式來實現(xiàn)呢?就像elem.getElementsByTagName,我的想法是靈活selector string吧。

querySelector只返回匹配的第一個元素,如果沒有匹配項,返回null。

querySelectorAll返回匹配的元素集合,如果沒有匹配項,返回空的nodelist(節(jié)點數(shù)組)。

并且返回的結果是靜態(tài)的,之后對document結構的改變不會影響到之前取到的結果。

目前IE8+,ff,chrome都支持此api(IE8中的selector string只支持css2.1的)。

相關文章

  • js的隱含參數(shù)(arguments,callee,caller)使用方法

    js的隱含參數(shù)(arguments,callee,caller)使用方法

    本篇文章只要是對js的隱含參數(shù)(arguments,callee,caller)使用方法進行了介紹,需要的朋友可以過來參考下,希望對大家有所幫助
    2014-01-01
  • JavaScript的面向?qū)ο?一)

    JavaScript的面向?qū)ο?一)

    JavaScript的面向?qū)ο?一)...
    2006-11-11
  • JavaScript獲取/更改文本框的值的實例代碼

    JavaScript獲取/更改文本框的值的實例代碼

    這篇文章介紹了JavaScript獲取/更改文本框的值的實例代碼,有需要的朋友可以參考一下
    2013-08-08
  • JavaScript針對SPA應用的前端優(yōu)化策略概述

    JavaScript針對SPA應用的前端優(yōu)化策略概述

    前端性能優(yōu)化是Web開發(fā)中非常重要的一環(huán),優(yōu)化能夠有效地提高網(wǎng)站的加載速度和用戶體驗,而對于SPA來說,由于其特殊的加載方式和數(shù)據(jù)交互方式,其優(yōu)化策略也具有一定的特殊性,需要詳細了解可以參考下文
    2023-05-05
  • 2種簡單的js倒計時方式

    2種簡單的js倒計時方式

    這篇文章主要為大家詳細介紹了2個簡單js倒計時方式,一是帶天數(shù)的倒計時,二是單純分鐘和秒倒計時,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-10-10
  • ionic2打包android時gradle無法下載的解決方法

    ionic2打包android時gradle無法下載的解決方法

    這篇文章主要為大家詳細介紹了ionic2打包android時gradle無法下載的解決方法,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-04-04
  • 微信小程序?qū)崿F(xiàn)select下拉框

    微信小程序?qū)崿F(xiàn)select下拉框

    這篇文章主要為大家詳細介紹了微信小程序?qū)崿F(xiàn)select下拉框,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-07-07
  • JavaScript實現(xiàn)拖拽功能

    JavaScript實現(xiàn)拖拽功能

    這篇文章主要為大家詳細介紹了JavaScript實現(xiàn)拖拽功能,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-02-02
  • 關于刪除時的提示處理(確定刪除嗎)

    關于刪除時的提示處理(確定刪除嗎)

    在刪除時為了提醒用戶刪除數(shù)據(jù)的不可恢復一般都會有提示處理的,通常會使用js做到這一點,下面有個不錯的示例,感興趣的朋友可以參考下
    2013-11-11
  • javascript數(shù)組常用方法匯總

    javascript數(shù)組常用方法匯總

    這篇文章主要匯總了javascript中數(shù)組常用方法,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2016-09-09

最新評論