本篇內容主要就是元素選擇器功能用Javascript實現。
首先說下什么是元素選擇器?
想必大家對于jquery很了解,知道它有對元素的查找功能,解釋來說就是通過jquery的api獲取頁面元素的過程,該過程只需提供一個元素選擇的條件字符串即可獲取相應的滿足條件的頁面元素。元素選擇器即是指通過條件字符串獲取相應元素的一個工具函數。
元素選擇器分為id選擇器、class選擇器、標簽選擇器以及屬性選擇器。
id選擇器即通過元素的id唯一標識獲取元素。
類選擇器即通過元素的class類獲取元素列表。
標簽選擇器即通過元素的標簽名獲取元素列表。
屬性選擇器即通過元素的屬性獲取元素列表。
元素選擇器的實現方法可以由javascript的document對象提供的方法來完成,document對象的關于元素獲取的方法有
1、getElementById
2、getElementsByClassName
3、getElementsByTagName
這是三種比較常用的獲取頁面元素的方法。
一個簡單的元素選擇器實現
function node(selector) { if(selector.indexOf("#")==0) { var dom = document.getElementById(selector.substring(1)); FE.extend("addClass",dom,addClass); FE.extend("removeClass",dom,removeClass); FE.extend("prevNode",dom,prevNode); FE.extend("value",dom,value); FE.extend("styleSettings",dom,styleSettings); FE.extend("nextNode",dom,nextNode); return dom; }else if(selector.indexOf(".")==0) { var doms = document.getElementsByClassName(selector.substring(1)); var result = []; for(var i=0;i<doms.length;i++) { FE.extend("addClass",doms[i],addClass); FE.extend("removeClass",doms[i],removeClass); FE.extend("prevNode",doms[i],prevNode); FE.extend("value",doms[i],value); FE.extend("styleSettings",doms[i],styleSettings); FE.extend("nextNode",doms[i],nextNode); result.push(doms[i]); } return result; }else { var start = selector.indexOf("["); var end = selector.indexOf("]"); var tagName = selector.substring(0,start); var attrStr = selector.substring(start+1,end); var attr = attrStr.split("="); var doms = document.getElementsByTagName(tagName); var result = []; for(var i=0;i<doms.length;i++) { var attrName = attr[0]; var value = doms[i].getAttribute(attrName) if("'"+value+"'" == attr[1]) { FE.extend("addClass",doms[i],addClass); FE.extend("removeClass",doms[i],removeClass); FE.extend("prevNode",doms[i],prevNode); FE.extend("value",doms[i],value); FE.extend("styleSettings",doms[i],styleSettings); FE.extend("nextNode",doms[i],nextNode); result.push(doms[i]); } } return result; } }
元素選擇器實現總結
言簡意賅說元素選擇器實現了對元素獲取方法的封裝,每次獲取頁面元素時都不需要再次使用document對象提供的方法,只需使用工具函數node即可獲取頁面元素中滿足selector條件字符串的元素,由于頁面元素還具有其它的共同特性,比如修改元素的class屬性的方法addClass、removeClass,修改和獲取style屬性的方法styleSettings,修改和獲取元素屬性的方法value,以及獲取當前元素的上一個元素和下一個元素的方法prevNode、nextNode等。
上面可以通過一個擴展對象的類方法extend綁定到相應的元素上,不需要再次調用或者寫相應的代碼去獲取或者修改,extend類方法允許擴展任意對象的任意屬性,在javascript中一切變量都可以看作一個對象,除了簡單的基本類型的變量外,我們可以使用像這樣的代碼來獲取和修改對象的屬性
var o = {name:"fe_spiderman",username:"路爺交歡"} /*通過對象引用方式獲取對象的屬性*/ o.name /*通過鍵值對的方式獲取對象的屬性*/ o[“name”]
上面代碼主要表達的就是用javascript豐富了對象的可擴展性,想象一下不用去繼承和封裝相應的接口來維護代碼的可讀性帶來的樂趣。學習開發也有不少樂趣,希望大家可以帶著更多快樂學習。
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/128229.html
摘要:取決于你的高度咦還是不能動因為我們還需要運用的兩個重要技巧偽類和通用兄弟元素選擇器,才能讓選項卡與內容塊做切換。加入偽類與通用兄弟元素選擇器我們為加上偽類,表示當這個被選中時等于對應的標簽被選中使才會呈現的樣式。 先看看Demo: showImg(https://segmentfault.com/img/bVbsMDs?w=481&h=395); CODEPEN 示例頁面 講到選項卡(...
摘要:取決于你的高度咦還是不能動因為我們還需要運用的兩個重要技巧偽類和通用兄弟元素選擇器,才能讓選項卡與內容塊做切換。加入偽類與通用兄弟元素選擇器我們為加上偽類,表示當這個被選中時等于對應的標簽被選中使才會呈現的樣式。 先看看Demo: showImg(https://segmentfault.com/img/bVbsMDs?w=481&h=395); CODEPEN 示例頁面 講到選項卡(...
摘要:取決于你的高度咦還是不能動因為我們還需要運用的兩個重要技巧偽類和通用兄弟元素選擇器,才能讓選項卡與內容塊做切換。加入偽類與通用兄弟元素選擇器我們為加上偽類,表示當這個被選中時等于對應的標簽被選中使才會呈現的樣式。 先看看Demo: showImg(https://segmentfault.com/img/bVbsMDs?w=481&h=395); CODEPEN 示例頁面 講到選項卡(...
摘要:希望在做所有事情之前,操作文檔。不受層級限制子選擇器在給定的父元素下匹配所有子元素。相鄰選擇器匹配所有緊接在元素后的元素。判斷當前對象中的某個元素是否包含指定類名,包含返回,不包含返回下標過濾器精確選出指定下標元素獲取第個元素。 原文鏈接 http://blog.poetries.top/2016... 首先,來了解一下jQuery學習的整體思路 showImg(https://seg...
摘要:一個專注于瀏覽器端和兼容的包管理器。一個整合和的最佳思想,使開發者能快速方便地組織和編寫前端代碼的下一代包管理器。完全插件化的工具,能在中識別和記錄模式。健壯的優雅且功能豐富的模板引擎。完整的經過充分測試和記錄數據結構的庫。 【導讀】:GitHub 上有一個 Awesome – XXX 系列的資源整理。awesome-javascript 是 sorrycc 發起維護的 JS 資源列表...
閱讀 561·2023-03-27 18:33
閱讀 750·2023-03-26 17:27
閱讀 647·2023-03-26 17:14
閱讀 603·2023-03-17 21:13
閱讀 537·2023-03-17 08:28
閱讀 1823·2023-02-27 22:32
閱讀 1315·2023-02-27 22:27
閱讀 2199·2023-01-20 08:28