×

Javascript:实现元素选择器功能

作者:abc1232022.09.30来源:Web前端之家浏览:667评论:0
关键词:js

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

您的支持是我们创作的动力!
温馨提示:本文作者系 ,经Web前端之家编辑修改或补充,转载请注明出处和本文链接:
https://jiangweishan.com/article/js20220930a1.html

网友评论文明上网理性发言 已有0人参与

发表评论:

ad

最新留言

  • fg123

    提示什么报错信息?...

  • 访客

    为什么第一步点击提交后弹出框点击确认后没有反应?...

  • fati

    刚好遇到setState的问题,感谢分享!...

  • derv3

    现在已经很多开源CMS了,对于个人来说,自己开发难度极大。...

  • derv3

    Cookies很多用途吧...

  • 访客

    sddddddddddddddVS的vVSVS但是v方法v方法v发v方法v发v发v方不方便德文法文...

  • 没人发言

    鸡肋的功能...

  • 23b

    这个你应该加群找群主才对吧...

首页|JavaScript|HTML|HTML4|HTML5|CSS3|开发工具|性能优化|移动开发|前端教程|性能优化|开发工具|酷站欣赏|UI设计|前端教程

Copyright © 2022 Web前端之家(www.jiangweishan.com) 版权所有 All Rights Reserved.
粤ICP备12067512号-1

Copyright Your WebSite.Some Rights Reserved.

Powered By Z-BlogPHP 1.7.2