Javascript实现元素选择器功能

本文实例为大家分享了Javascript实现元素选择器功能的具体代码,供大家参考,具体内容如下

什么是元素选择器?

用过jquery的开发者都知道,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的这种支持极大的丰富了对象的可扩展性,想象一下不用去继承和封装相应的接口来维护代码的可读性带来的乐趣。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我们。

(0)

相关推荐

  • Javascript封装id、class与元素选择器方法示例

    由于各个浏览器都支持的选择方法只有如下三种: 1.document.getElementById() 2.document.getElementsByName() 3.document.getElementsByTagName() 所以在封装选择器的时候要考虑浏览器的兼容性. 示例代码如下: <script>//封装id选择器 function $(selector){ var c=selector.substring(0,1);//获取第一个字符 if(c=="#"){

  • Javascript实现元素选择器功能

    本文实例为大家分享了Javascript实现元素选择器功能的具体代码,供大家参考,具体内容如下 什么是元素选择器? 用过jquery的开发者都知道,jquery封装了对元素的查找功能,即通过jquery的api获取页面元素的过程,该过程只需提供一个元素选择的条件字符串即可获取相应的满足条件的页面元素.元素选择器即是指通过条件字符串获取相应元素的一个工具函数. 元素选择器分为id选择器.class选择器.标签选择器以及属性选择器. id选择器即通过元素的id唯一标识获取元素. 类选择器即通过元素的

  • JavaScript前端页面搜索功能案例【基于jQuery】

    本文实例讲述了JavaScript前端页面搜索功能.分享给大家供大家参考,具体如下: 今天给大家分享一篇关于前端页面搜索的案例,有了这个案例,在表格数据中可以进行快速查找,比在浏览器中使用ctrl+F体验比较好. 效果图: 代码: <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>页面搜索实例</title>

  • JQuery常用选择器功能与用法实例分析

    本文实例讲述了JQuery常用选择器功能与用法.分享给大家供大家参考,具体如下: JQuery基础回顾 今天对JQuery内容进行了回顾,下面进行一些总结: JQuery是javascript的一个库,所以二者可以相互转换,例如JQuery到Javascript,用$()获取元素,传给JS的var变量.反之JS的getElement方法获取var变量后,可以通过$(var)转化成JQuery对象. JQuery的选择器, id选择$("#id"),class选择$(".cla

  • Scrapy元素选择器Xpath用法汇总

    众所周知,在设计爬虫时,最麻烦的一步就是对网页元素进行分析,目前流行的网页元素获取的工具有BeautifulSoup,lxml等,而据我使用的体验而言,Scrapy的元素选择器Xpath(结合正则表达式)是其中较为出色的一种(个人认为最好啦,当然只能在Scrapy中使用)功能相对较全.使用较为方便,正因为它的丰富性,有时很多功能会忘记,所以在这里整理好记录下来,方便今后查阅使用. 1. 元素的多级定位与跳级定位 多级定位:依靠html中的多级元素逐步缩小范围 response.xpath('//

  • JS仿JQuery选择器功能

    JQuery作为应用最广的JS库,其最强大的功能之一就是几乎涵盖所有方法的且代码十分简短的选择器功能,我们也可用自己的代码实现此功能,代码逻辑.使用方法与JQuery一致 function ZQuery(arg){ this.elements = []; //存东西 this.domString = ''; //保存字符串标签 if(typeof arg=='function'){ //DOMReady DOMReady(arg); }else if(typeof arg=='string'||

  • jQuery选择器之表单元素选择器详解

    本文实例为大家分享了表单元素选择器,供大家参考,具体内容如下 <!DOCTYPE html> <html> <head> <meta http-equiv="Content-type" content="text/html; charset=utf-8" /> <title></title> <link rel="stylesheet" href="imooc

  • jQuery选择器之子元素选择器详解

    本文实例为大家分享了jQuery子元素选择器,供大家参考,具体内容如下 <!DOCTYPE html> <html> <head> <meta http-equiv="Content-type" content="text/html; charset=utf-8" /> <title></title> <link rel="stylesheet" href="

  • 常用Javascript函数与原型功能收藏(必看篇)

    如下所示: // 重复字符串 String.prototype.repeat = function(n) { return new Array(n+1).join(this); } // 替换全部 String.prototype.replaceAll = function(str1, str2) { return this.replace(new RegExp(str1, "gm"), str2); } // 清除空格 String.prototype.trim = function

  • jQuery元素选择器实例代码

    本文实例为大家分享了jQuery元素选择器的具体代码,供大家参考,具体内容如下 <!DOCTYPE html> <html> <head> <meta http-equiv="Content-type" content="text/html; charset=utf-8" /> <title></title> <style> div { width: 100px; height: 9

  • jQuery元素选择器用法实例

    本文实例讲述了jQuery元素选择器用法.分享给大家供大家参考.具体分析如下: 元素选择器根据元素名称匹配所有的元素. 实例代码: 复制代码 代码如下: $("div") 以上代码匹配所有的div元素. 实例代码: 复制代码 代码如下: <!DOCTYPE html>   <html>   <head>   <meta charset=" utf-8">   <meta name="author&quo

随机推荐