<!DOCTYPE html>
<html>
    <head>
        <meta charset="UTF-8">
        <title></title>
        <link rel="stylesheet" type="text/css" href="base.css"/>
        <script src="sizzle.js" type="text/javascript" charset="utf-8"></script>
    </head>
    <body>
        <input type="button" id="btn" value="click" />
        <div id="ids" >
            <span>12</span>
            <div class="a">11</div>
            <div class="a">12</div>
            <div class="a">13</div>
        </div>
        
        <div><p class="a">3</p></div>
        
        
        <p>3</p>
        <script>
            var Base=function(args){
                this.elements=[];
                if(typeof args=="string")//string证明附带参数进来
                {
                    for(var i=0;i<Sizzle(args).length;i++)
                    {        
                        this.elements.push(Sizzle(args)[i]);
                    }
                }
                else if(typeof args=="object")
                {
                    if(args!=undefined)
                    {
                        this.elements[0]=args;
                    }
                }
            }
            var myquery=function(args){
                return new Base(args);
            }

//            //id弃用,使用sizzle来获取
//            Base.prototype.getid=function(args){
//                var thisid=document.getElementById(args);
//                return this.elements.push(thisid)
////                return this;
//            };
            //tag
//            Base.prototype.gettags=function(args){
//                var tag=document.getElementsByTagName(args);
//                for(var i=0;i<tag.length;i++)
//                {
//                    this.elements.push(tag[i])
//                }
//                return this;
//            }
            //css
            Base.prototype.css=function(attr,value)
            {
                //console.log(arguments.length)
                if(typeof arguments[0]=="object"&&arguments.length==1)//传递的对象
                {
                    for(var i=0;i<this.elements.length;i++)
                    {
                        //alert(this.elements)
                        for(var key in arguments[0]){  
                            this.elements[i].style[key]=arguments[0][key];
                        }
                    }
                }
                else
                {
                    console.log("b")
                    for(var i=0;i<this.elements.length;i++)
                    {
                        if(arguments.length==1)
                        {
                            if(typeof window.getComputedStyle!=undefined)
                            {
                                //复合属性值无从获取在ie和火狐里面
                                return document.defaultView.getComputedStyle(this.elements[i],null)[attr];
                            }
                            else if(typeof this.elements[i].currentStyle!=undefined)
                            {
                                //console.log(this.elements[i].currentStyle[attr])
                                return this.elements[i].currentStyle[attr];
                            }
                        }
                        else
                        {
                            this.elements[i].style[attr]=value;
                        }
                        
                    }
                }
                
                return this;
            }
            //html
            Base.prototype.html=function(args){
                console.log(this.elements.length)
                for(var i=0;i<this.elements.length;i++)
                {
                    if(arguments.length==0)
                    {
                        return this.elements[i].innerHTML;
                    }
                    else
                    {
                        this.elements[i].innerHTML=args;
                    }
                    
                }
                return this;
            }
            //class
//            Base.prototype.getclass=function(attr,area){
//                //Sizzle(".a")[1]
//                var param=null;
//                if(arguments.length==2)
//                {
//                    for(var i=0;i<Sizzle(area+" ."+attr).length;i++)
//                    {        
//                        this.elements.push(Sizzle(area+" ."+attr)[i]);
//                    }
//                }
//                else
//                {
//                    var classes=document.getElementsByTagName("*");
//                    for(var i=0;i<classes.length;i++)
//                    {
//                        if(classes[i].className==attr)
//                        {
//                            //console.log(classes[i])
//                            this.elements.push(classes[i]);
//                        }
//                    }
//                }
//                return this;
//            }
            //eq方法
            Base.prototype.eq=function(num){
                var tempelement=this.elements[num];
                this.elements=[];
                this.elements[0]=tempelement;
                return this;
            }
            //addclass
            Base.prototype.addclass=function(classname){
                for(var i=0;i<this.elements.length;i++)
                {
                    //去重
                    if(!this.elements[i].className.match(new RegExp('(\\s|^)'+classname+'($|\\s)')))
                    {
                        this.elements[i].className+=" "+classname
                    }
                    
                }
                return this;
            }
            //removeclass
            Base.prototype.removeclass=function(classname){
                for(var i=0;i<this.elements.length;i++)
                {
                    //去重
                    if(this.elements[i].className.match(new RegExp('(\\s|^)'+classname+'($|\\s)')));
                    {
                        this.elements[i].className=this.elements[i].className.replace(new RegExp('(\\s|^)'+classname+'($|\\s)')," ");
                    }
                    
                }
                return this;
            }
//            //addcss
//            Base.prototype.addcss=function(num,selectortxt,csses,ind){
//                var sheet=document.styleSheets[num];
//                if(typeof sheet.insertRule!=undefined)
//                {
//                    sheet.insertRule(selectortxt+"{"+csses+"}",ind)
//                }
//                else if(sheet.addRule!=undefined)
//                {
//                    sheet.addRule(selectortxt,csses,ind)
//                }
//                return this;
//            }
//            //removecss
//            Base.prototype.removecss=function(num,ind){
//                var sheet=document.styleSheets[num];
//                if(typeof sheet.deleteRule!=undefined)
//                {
//                    sheet.deleteRule(ind)
//                }
//                else if(sheet.removeRule!=undefined)
//                {
//                    sheet.removeRule(ind)
//                }
//                return this;
//            }
            //插件扩展
            Base.prototype.extend=function(name,fn){
                Base.prototype[name]=fn;
            }
//            myquery().extend('bbb',function(){
//                alert("a")
//            })
//            myquery().bbb();
            //现代事件绑定
            
            Base.prototype.addevent=function(obj,type,fn){
                if(typeof obj.addEventListener!='undefined')
                {
                    obj.addEventListener(type,fn,false);
                }
                else
                {
                    if(!obj.events)
                    {
                        obj.events={};
                    }
                    if(!obj.events[type])
                    {
                        obj.events[type]=[];
                        if(obj.events["on"+type])//如果没有ontype点击事件,那么我们把fn存放到第一个type的位置
                        {
                            obj.events[type][0]=fn;
                        }
                    }
                    else
                    {
                        if(Base.prototype.addevent.compare(obj.events[type],fn))
                        return false;
                    }
                    obj.events[type][Base.prototype.addevent.countnum++]=fn;
                    obj["on"+type]=Base.prototype.addevent.exec;
                }
            }
            Base.prototype.addevent.countnum=1;//ie8一下事件计数器
            Base.prototype.addevent.exec=function(e){
                var e=event||window.event;
                for(var i in this.events[e.type])
                {
                    this.events[e.type][i].call(this,e);
                }
            }
            Base.prototype.addevent.compare=function(type,fn){
                
                for(var i in type)
                {
                    if(type[i]==fn)
                    {
                        return true;
                    }
                }
                return false;
            }
            //现代事件删除
            Base.prototype.removevent=function(obj,type,fn){
                if(typeof obj.removeEventListener!='undefined')
                {
                    obj.removeEventListener(type,fn,false);
                }
                else
                {
                    for(var i in obj.events[type])
                    {
                        if(obj.events[type][i]==fn)
                        {
                            delete obj.events[type][i];
                        }
                    }
                }
            }
console.log(myquery("div p").eq(0).css({"color":"red","background":"red"}))
//var objs=document.getElementById("btn");
//            myquery().addevent(objs,"click",fn1)
//            myquery().addevent(objs,"click",fn1)
//            myquery().addevent(objs,"click",fn1)
//            myquery().removevent(objs,"click",fn1)
//            
//            function fn1(){
//                alert("a1"+this.value)
//            }
//            function fn2(){
//                alert("a2"+this.value)
//            }
//            function fn3(){
//                alert("a3"+this.value)
//            }
            //console.log(Sizzle("#ids .a")[2].innerHTML)
        </script>
        
    </body>
</html>

js库开发--参数传递及方法修改的更多相关文章

  1. ArcServer JS API开发离线部署方法

      1. 下载ArcGIS API for JavaScript 3.6 Library. (地址:http://support.esrichina.com.cn/uploadfile/Javascr ...

  2. js库开发

    <!DOCTYPE html><html>    <head>        <meta charset="UTF-8">      ...

  3. js库编写的环境和准备工作

    在编写一个js库之前需要准备许多基础知识. 本人在编写之前主要参考了visjs和百度的echarts这两个库的部分内容,这之中提取出几个要点如下: 1.如何整理代码结构,使模块与模块分开又不至于出现调 ...

  4. 动态嵌套form,使用Stimulus Js库(前后端不分离)

    我的git代码:https://github.com/chentianwei411/nested_form-Stimulus- Stimulus:     https://www.cnblogs.co ...

  5. 解决同一页面jQuery多个版本或和其他js库冲突方法

    <!DOCTYPE html> <html lang="en" xmlns="http://www.w3.org/1999/xhtml"> ...

  6. ios实例开发精品文章推荐(8.12)11个处理触摸事件和多点触摸的JS库

    11个处理触摸事件和多点触摸的JS库 触摸屏是现在所有智能手机的标配,还包括各种平板设备,而且很多桌面也慢慢在开始支持触摸操作.要开发支持触摸屏设备的Web应用,我们需要借助浏览器的触摸事件来实现. ...

  7. 使用模块化工具打包自己开发的JS库(webpack/rollup)对比总结

    打包JS库demo项目地址:https://github.com/BothEyes1993/bes-jstools 背景 最近有个需求,需要为小程序写一个SDK,监控小程序的后台接口调用和页面报错(类 ...

  8. 解决jQuery多个版本,与其他js库冲突方法

    jQuery多个版本或和其他js库冲突主要是常用的$符号的问题,这个问题 jquery早早就有给我们预留处理方法了,下面一起来看看解决办法. 1.同一页面jQuery多个版本或冲突解决方法. < ...

  9. <WEB>平板_手机开发_13 个处理触摸事件和多点触摸的JS 库

    触摸屏是现在所有智能手机的标配,还包括各种平板设备,而且很多桌面也慢慢在开始支持触摸操作.要开发支持触摸屏设备的 Web 应用,我们需要借助浏览器的触摸事件来实线. 下图是各种触摸事件说明: 本文我们 ...

随机推荐

  1. 线程:CyclicBarrier同步工具类

    一个同步辅助类,它允许一组线程互相等待,直到到达某个公共屏障点.比如公司组织活动出去玩,需要在公司门口一起搭车去.每个人从家里出发去公司门口,到达的时间肯定先后不一样,所以公司的车要一直等待,等所有人 ...

  2. VML :Vector Markup Language

    在以前老是浏览器IE<9在不支持SVG情况下,IE一般通过VML来绘制图形,图片,文字等 步骤: 必须在头部添加 <HTML xmlns:v="urn:schemas-micro ...

  3. jquery插件autocomplete

    项目中有时会用到自动补全查询,就像Google搜索框.淘宝商品搜索功能,输入汉字或字母,则以该汉字或字母开头的相关条目会显示出来供用户选择, autocomplete插件就是完成这样的功能. < ...

  4. ExtJS 创建动态加载树

    Ext 中导航树的创建有两种方式:1.首先将所有的数据读出来,然后绑定到前台页面.2.每点击一个节点展开后加载子节点.在数据量比较小的时候使用第一种方式加载的会快一些,然而当数据量比较大的时候,我还是 ...

  5. CentOS安装配置ganglia

    1.     下载ganglia源码包并解压 wget http://sourceforge.net/projects/ganglia/files/ganglia%20monitoring%20cor ...

  6. Fedora19/18/17安装显卡驱动和无限网卡驱动

    一.安装nvidia显卡驱动 1. 切换到root用户          su - 2. 确定当前Linux内核及SELinux policy 是否为最新          yum update ke ...

  7. [c language] getopt

    getopt(分析命令行参数)     相关函数表头文件         #include<unistd.h>定义函数         int getopt(int argc,char * ...

  8. Python学习(六) Python数据类型:字典(重要)

    字典dict: 字典其实就相当于java里面的Map,用来存储键值对的.其中存储的数据时无序的. 假如有这样的数据: t1=['name','age','sex'] t2=['tom',30,'mal ...

  9. BC 65 ZYB's Premutation (线段树+二分搜索)

    题目简述:有一个全排列,一直每个前缀区间的逆序对数,还原这个排列. fi记录逆序对数,pi记录该位置数值,则k=fi-f(i-1)表示前i-1个数比pi大的数的个数,那么只要在剩余元素求出按大小顺序第 ...

  10. 苹果开发证书相关BLOG与Delphi IOS环境安装(超详细)

    注:有好的资源,请添加了上传,上传后,通知管理员,删除旧文件,累积相关的学习资源,方便新手学习 一.相关论坛http://www.2ccc.com/ delphi 合子 www.2pascal.com ...