公司一直使用jQuery框架,一些小的项目还是觉得jQuery框架太过于强大了,于是自己周末有空琢磨着写个自己的框架。谈到js的设计模式,不得不说说js的类继承机制,javascript不同于PHP可以轻松的实现类继承,不过javascript的类继承方法还是有的,常见的有构建函数、原型扩展、综合……,也有一些专门写类的函数,例如jQuery的作者有个类继承函数。关于类继承写法可以简单看 
_________________________________________________________________________________________________ 
公司一直使用 
jQuery插件 
框架,一些小的项目还是觉得jQuery框架太过于强大了,于是自己周末有空琢磨着写个自己的框架。谈到js的设计模式,不得不说说js的类继承机制, 
javascript 
不同于PHP可以轻松的实现类继承,不过 
javascript 
的类继承方法还是有的,常见的有构建函数、原型扩展、综合……,也有一些专门写类的函数,例如jQuery的作者有个类继承函数。关于类继承写法可以简单看看

我自己写的框架也不知道叫什么名字,刚开始写的时候随手写了个W(姓拼音,之前写过jQuery弹出框插件wBox),现在写这篇文章重新整理了一下思想,换了YQ(名字拼音,你懂的~)。

核心代码

框架设计的时候尽量做到了支持链式写法,也就是返回this,可以$(selector).handler1().handler2()……无限写下去,只要不是有返回值的就可以继续。包括了event,dom,css,还有fadeIn,fadeOut动画(因为再重构爱墙[html5+css3]版,所有顺手加上了这个功能)。如果配合sizzle选择器就更牛了!

下面说说框架的核心代码,等完善了之后跟新版html5爱墙一起放出,主要的代码如下:

(function(window,document){ 
    var DOC = document,YQ = window.$ = function(selector){ 
        if(!selector){ 
            return YQ.elems 
        } 
        typeof selector === 'string' && (selector = getElements(selector));//简单的判断是dom对象,还是字符串,字符串则开始选择器 
        return superElems(selector); 
    } 
    function superElems(elems){ 
        if(elems){ 
            if(elems.nodeType){//判断是否为DOM 
                if(typeof elems.getAttribute !=="unknown"){ 
                    var temp = elems; 
                    elems = []; 
                    elems[0] = temp;//把本身作为超级对象的第一个,其他方法进行扩展 
                    for(var i in YQ.elems){ 
                        //扩展对象,保留已有的方法 
                        typeof elems[i] === "undefined" && (elems[i] = YQ.elems[i]) 
                    } 
                } 
            }else{//如果为对象,则对对象进行扩展 
                elems = YQ.extend(elems,YQ.elems); 
            } 
        } 
        return elems; 
    } 
    function getElements(selector){ 
        //伟大的选择器,可以使用sizzle 
        var dom = DOC.getElementById(selector);//…… 
        return dom; 
    } 
    YQ.tool = { 
        isFunction:function(obj){//简单的判断是否为函数 
            return obj && typeof obj ==="function"; 
        } 
    } 
    //此处为超级对象一些扩展 
    YQ.elems = { 
        each:function(dom,callback){//强大的each 
            if(YQ.tool.isFunction(dom)){ 
                arguments.callee.call(this,this,dom); 
            }else{ 
                for (var i = 0, len = dom.length; i < len; i++) { 
                    callback.call(dom, i, dom[i]); 
                } 
            } 
            return this; 
        }, 
        find:function(selector){ 
            var doms = []; 
            this.each(function(i,dom){ 
                doms.push(YQ.DOM.find(selector,dom)); 
            }) 
            return superElems(doms); 
        } 
    } 
    YQ.each = window.Array.prototype.each = YQ.elems.each;//扩展Array 
    YQ.extend = function(subClass,baseClass){ 
        for(var i in baseClass){ 
            subClass[i] = baseClass[i]; 
        } 
        return subClass; 
    } 
    YQ.AJAX = {} 
    YQ.CSS = { 
        names:{ 
            'float':'cssFloat',//区分cssFloat or styleFloat 
            opacity:'opacity' 
            //…… 
        } 
    } 
    YQ.browser = { 
        isIE:'', 
        isFirefox:'', 
        version:'3.6' 
        //…… 
    } 
    YQ.event = { 
        names:{ 
            mousewheel:YQ.browser?"DOMMouseScroll":"mousewheel" 
        }, 
        fix:function(e){ 
            if(e && e.clone) return e;//如果已经处理了,直接返回 
            e = window.event || e;//event是全局变量 
            var fixE = { 
                clone:true, 
                stop:function(){//冒泡 
                    if(e&&e.stopPropagation){ 
                        e.stopPropagation(); 
                    }else{ 
                        e.cancleBubble = true 
                    } 
                }, 
                prevent:function(){//默认动作 
                    if(e && e.preventDefault){ 
                        e.preventDefault(); 
                    }else{ 
                        e.returnValue = false; 
                    } 
                }, 
                target:e.target || e.srcElement, 
                x:e.clientX || e.pageX, 
                Y:e.clientY || e.pageY, 
                //鼠标滚轮事件统一处理 
                wheel:e.wheelDelta/120 || -e.detail/3 
            } 
            return fixE; 
        } 
    } 
    YQ.DOM = { 
        find:function(selector,parentDom){ 
            //do something 
        } 
    }})(window,document); 
简单的分析

代码中的注释还算详细,结合注释就可以看懂,下面我再多说几句,高手飘过,欢迎拍砖…… 
总得来看是个匿名函数,定义了全局变量$(似乎都喜欢美元,如果有喜欢的人民币的,下次加上),函数里面有个YQ的对象,有很多function,包括一些私有的。

使用$可以作为选择器,如果为空,则返回YQ.elems对象,选择后的DOM根据YQ.elems进行扩展,最后得到的就是注释里面说的superElems(此处创建superElems方法参考了下jRaiser),跟jQuery的superElems类似,绑定了很多方法,可以方便的进行操作,YQ的方法可以通过YQ.elems扩展到选择器选择的对象上去,而选择器主要的函数getElements,可以使用sizzle,这样就方便了dom操作,不过sizzle似乎也是代码太多,此处将来会支持简单的标签,#ID,.class,标签+class选择器。

另外框架中中对一些Array,string进行了扩展,例如上面的Array.each方法,YQ.elems.each是重量级的函数方法,可以支持superElems的遍历(返回本身),还可以支持简单数组的遍历。

框架中还对一些兼容性进行了处理,例如YQ.event.fix处理事件,css中处理float

基本就这些了,今天就先说核心的部分,其实通过这段代码已经很清晰的了解到这个框架的思想了,后续继续给力的coding,补充扩展…… 
目前为止,框架不到800行代码,包括了常见的jQuery方法,压缩后不到9k,gzip 4.5K~

查看更多:

http://www.huiyi8.com/jiaoben/

http://www.huiyi8.com/js/css/

写的一个轻量级javascript框架的设计模式的更多相关文章

  1. NET Core写了一个轻量级的Interception框架[开源]

    NET Core写了一个轻量级的Interception框架[开源] ASP.NET Core具有一个以ServiceCollection和ServiceProvider为核心的依赖注入框架,虽然这只 ...

  2. 2016 年 50 个最佳的轻量级 JavaScript 框架和库

    作者:IT程序狮链接:https://zhuanlan.zhihu.com/p/24598210来源:知乎著作权归作者所有.商业转载请联系作者获得授权,非商业转载请注明出处. 回顾今年已发布的 JS ...

  3. 基于Netty和SpringBoot实现一个轻量级RPC框架-协议篇

    基于Netty和SpringBoot实现一个轻量级RPC框架-协议篇 前提 最近对网络编程方面比较有兴趣,在微服务实践上也用到了相对主流的RPC框架如Spring Cloud Gateway底层也切换 ...

  4. 基于Netty和SpringBoot实现一个轻量级RPC框架-Server篇

    前提 前置文章: Github Page:<基于Netty和SpringBoot实现一个轻量级RPC框架-协议篇> Coding Page:<基于Netty和SpringBoot实现 ...

  5. 基于Netty和SpringBoot实现一个轻量级RPC框架-Client篇

    前提 前置文章: <基于Netty和SpringBoot实现一个轻量级RPC框架-协议篇> <基于Netty和SpringBoot实现一个轻量级RPC框架-Server篇> 前 ...

  6. 基于Netty和SpringBoot实现一个轻量级RPC框架-Client端请求响应同步化处理

    前提 前置文章: <基于Netty和SpringBoot实现一个轻量级RPC框架-协议篇> <基于Netty和SpringBoot实现一个轻量级RPC框架-Server篇> & ...

  7. 为了支持AOP的编程模式,我为.NET Core写了一个轻量级的Interception框架[开源]

    ASP.NET Core具有一个以ServiceCollection和ServiceProvider为核心的依赖注入框架,虽然这只是一个很轻量级的框架,但是在大部分情况下能够满足我们的需要.不过我觉得 ...

  8. 分享一个CSS+JavaScript框架materializecss

    一.内容: CSS+JavaScript框架materializecss. 二.网址:http://materializecss.com 三.图片:

  9. 2018.2.5 PHP如何写好一个程序用框架

    随着PHP标准和Composer包管理工具的面世,普通开发者撸一个框架已经不再是什么难事了. 无论是路由管理.ORM管理.还是视图渲染都有许许多多优秀的包可以使用.我们就像堆积木一样把这些包用comp ...

随机推荐

  1. plus接口

    //获取手机端本地文件路径 plus.io.resolveLocalFileSystemURL(url, success(e){ }, fail(e){ })

  2. 吴裕雄 python 神经网络——TensorFlow训练神经网络:MNIST最佳实践

    import os import tensorflow as tf from tensorflow.examples.tutorials.mnist import input_data INPUT_N ...

  3. 线程同步 - POSIX互斥锁

    线程同步 - POSIX互斥锁 概括 本文讲解POSIX中互斥量的基本用法,从而能达到简单的线程同步.互斥量是一种特殊的变量,它有两种状态:锁定以及解锁.如果互斥量是锁定的,就有一个特定的线程持有或者 ...

  4. Golang介绍以及安装

    Go语言 Google开源 编译形语言 21世纪的C语言 Go语言的特点 简单易并发 开发效率高 执行性能好 Go语言应用的领域 服务端开发 日志处理 文件系统 监控服务 容器虚拟化 Docker k ...

  5. 看完这篇微服务架构设计思想,90%的Java程序员都收藏了

    本博客强烈推荐: Java电子书高清PDF集合免费下载 https://www.cnblogs.com/yuxiang1/p/12099324.html 微服务 软件架构是一个包含各种组织的系统组织, ...

  6. 在IDEA中为SpringBoot配置热部署

    版本:IDEA Community 2019.2.2,Spring Boot  2.1.8.RELEASE 流程:pom文件中添加依赖: <dependency> <groupId& ...

  7. Spring学习(三)

    DI (Dependency Injection) 1.依赖注入,组件之间的依赖关系由容器在运行期间决定.Ioc容器注入应用程序某个对象,它所需要的外部资源(包括对象,资源,常量数据). birthd ...

  8. JavaScript学习笔记----- 继承的实现及其原理

    按照自己在极客上学习的顺序整理了一下,参考了几位前辈的随笔,十分感谢:                       参见http://blog.yemou.net/article/query/info ...

  9. 学习笔记(16)- InsuranceQA_zh

    仓库地址:https://github.com/l11x0m7/InsuranceQA_zh Convolutional Neural Network for Chinese InsuranceQA ...

  10. 凭什么相信 5G 很安全?

    导读 电信行业及其专家指责科学家说,他们研究的5G无线技术所带来的手机辐射制造了恐慌.由于我们的许多研究工作都是由公共资助的,因此我们相信从道德的角度来看,我们有责任告知公众,经过同行评审的科学文献究 ...