js中扩展内置对象的正确姿势

错误的扩展

/*
* 这样做是不允许的,会污染原生对象Function 
*/
Function.prototype.checkUserName = function () { };
var f1 = function () { };
f1.checkUserName();/*
* 这样做是不允许的,会污染原生对象Function 
*/
Function.prototype.checkUserName = function () { };
var f1 = function () { };
f1.checkUserName();

正确的做法

Function.prototype.addMethod1 = function (name, fn) {
    this[name] = fn;
}
var f2 = function () { };
f2.addMethod1('checkUserName', function () {
    console.log('checkUserName');
})
f2.addMethod1('checkPhone', function () {
    console.log('checkPhone');
})
f2.checkUserName();
f2.checkPhone();

 链式调用(函数式调用方式)

Function.prototype.addMethod2 = function (name, fn) {
    this[name] = fn;
    // 这里返回this,是用于链式添加
    return this;
}
var f3 = function () { };
f3.addMethod2('checkUserName', function () {
    console.log('checkUserName');
    // 这里返回this,是用于链式调用
    return this;
})
    .addMethod2('checkPhone', function () {
        console.log('checkPhone');
        // 这里返回this,是用于链式调用
        return this;
    });
// 链式调用
f3.checkUserName().checkPhone();

链式调用(类式调用方式) 

Function.prototype.addMethod3 = function (name, fn) {
    // 放在原型对象上
    this.prototype[name] = fn;
    return this;
}
var f4 = function () { };
f4.addMethod3('checkUserName', function () {
    console.log('checkUserName');
    // 这里返回this,是用于链式调用
    return this;
}).addMethod3('checkPhone', function () {
    console.log('checkPhone');
    // 这里返回this,是用于链式调用
    return this;
});
// 使用的时候就需要注意了
var a = new f4();
a.checkUserName().checkPhone();
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

心上之秋

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值