JS面向对象实战(一)——创建一个新的函数对象的两种习惯

JavaScript面向对象(一)——创建一个新的函数对象的两种习惯

工作中可能习惯创建一个函数对象的方式,管理一个模块。那么针对创建一个函数对象,一般有两种习惯方式:偏向链式编程;偏向类

不能污染函数祖先Function。

我们如果想添加一个方法,一般而言,不能放到原生对象上。因为这样会污染原生对象,并且容易引发冲突。但是我们可以给原生对象Function抽象一个统一添加方法的方法:addMethod(),用来方便给Function的实例添加方法,作为一个模块的管理。

Function.prototype.addMethod = function(name,fn){
    this[name] = fn;
}

偏向链式编程

如果偏向链式编程的习惯,创建一个函数对象可以参考如下

1 修改抽象方法

Function.prototype.addMethod = function(name,fn){
    this[name] = fn;
    return this;
}

2 创建函数对象

var validate = function(){};

validate.addMethod('checkName', function(){
    // 验证姓名
    alert("checkName");
    return this;
}).addMethod('checkEmail',function(){
    // 验证邮箱
    alert("checkEmail");
    return this;
});

// 测试
validate.checkName().checkEmail();

偏向类

1 修改抽象方法

Function.prototype.addMethod = function(name,fn){
    this.prototype[name] = fn;
}

2 创建函数对象

var Methods = function(){};
Methods.addMethod('checkName', function(){
    // 验证姓名
    alert("checkName");
})
Methods.addMethod('checkEmail',function(){
    // 验证邮箱
    alert("checkEmail");
});

var m = new Methods();

m.checkName();
m.checkEmail();

个人偏向第二种方式,面向对象的思想更浓厚

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值