博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
JS框架设计之对象扩展一种子模块
阅读量:6221 次
发布时间:2019-06-21

本文共 1320 字,大约阅读时间需要 4 分钟。

对象扩展

说完了,对象的创建(框架的命名空间的创建)以及如何解决多库之间的命名空间冲突问题之后,接下来,就是要扩展我们的对象,来对框架进行扩展,我们需要一种新功能,将新添加的功能整合到我们定义的对象中去。这种类型的方法在Javascript中常被称为extend和mixin。在Javascript对象属性特性没有诞生之前,我们可以随意的添加、修改、删除其属性的,因此扩展一个对象十分的简单。一个简单的代码扩展方法如下:

Title

 

这个方法在旧版本的IE中存在bug,因为它认为Object的原型方法就不该被遍历出来,因此for in循环是无法遍历名为valueof 和 toString的属性名的属性名,这导致后来模拟实现Object.Keys()也遇到了困难。下面这个方法主要用于获取对象的属性,给那些在(js引擎没有实现Object.Keys)的浏览器中获取对象的属性用的

Title

 mass的对象扩展方法

var zc={};function extend(target,source){    //将arguements转换成数组对象    var args=[].slice.call(arguments); //slice如果不传递参数,则默认截取所有的参数    var i=1;//控制用户参数传入的开始遍历的位置    var key;    //arguements的最后一个参数,决定是不是要对重复的参数进行复写,并规定最后一个参数只能是boolean    var ride=typeof args[args.length-1]=="boolean"?args.pop():true;//获取最后一个参数,如果不是bool值默认为true    //当传入参数只有一个时候    if(args.length===1){        target=!this.window?this:{};    }    //从第二个参数开始遍历(因为第一个参数是,要追加属性的对象),一直遍历到最后一个参数,知道source=undefined时,结束遍历    while ((source=args[i++])){        for(key in source)        {            //如果复写,或者当前属性在target对象中不存在            if(ride || !(key in target))            {                //将属性写入到对象中                target[key]=source[key];            }        }    }    return target;}    extend(zc,{version:"1.0.0",name:"zcJsHelper"},{other:"other"},true,true);    alert(zc.other);

 

转载于:https://www.cnblogs.com/GreenLeaves/p/6410328.html

你可能感兴趣的文章
[python机器学习及实践(3)]Sklearn实现K近邻分类
查看>>
用pillow和 opencv做透明通道的两图混全(blend)
查看>>
POJ 1002 487-3279
查看>>
netty 4.x 用户手册翻译
查看>>
Acoustic:一个异常强大的wordpress商业模板
查看>>
逆元求法(转)
查看>>
HDU 4162 Shape Number【字符串最小表示】
查看>>
项目Beta冲刺(团队1/7)
查看>>
图片垂直居中的方法(适合只有一行文字和图片)
查看>>
HTTP、HTTP1.0、HTTP1.1、HTTP2.0、HTTPS
查看>>
XML约束技术
查看>>
Ubuntu软件包管理器
查看>>
【03】循序渐进学 docker:基础命令
查看>>
【转】Deep Learning(深度学习)学习笔记整理系列之(四)
查看>>
Protostuff序列化
查看>>
Servlet & Jsp
查看>>
python Image模块基本语法
查看>>
DS博客作业01--日期抽象数据类型设计与实现
查看>>
docker镜像的操作
查看>>
Tomcat 9.0安装配置
查看>>