我们使用jquery的时候,jquery的简单的语法及可实现链式调用方法,现在我们自己也封装一个链式调用的方法,来理解下 jquery中如何封装链式调用 无非就是每次调用一个方法的时候 给这个方法返回this即可,this指向该对象自身,我们看看代码:
1 // 定义一个简单的对象,每次调用对象的方法的时候,该方法都返回该对象自身 2 var obj = { 3 a: function(){ 4 console.log("输出a"); 5 return this; 6 }, 7 b:function(){ 8 console.log("输出b"); 9 return this; 10 } 11 }; 12 console.log(obj.a().b()); // 输出a 输出b 输出this指向与obj这个对象 13 14 // 下面我们再看下 上面的通过Function扩展类型添加方法的demo如下: 15 Function.prototype.method = function(name,func) { 16 if(!this.prototype[name]) { 17 this.prototype[name] = func; 18 return this; 19 } 20 } 21 22 String.method(‘trim‘,function(){ 23 return this.replace(/^\s+|\s+$/g,‘‘); 24 }); 25 String.method(‘log2‘,function(){ 26 console.log("链式调用"); 27 return this; 28 }); 29 String.method(‘r‘,function(){ 30 return this.replace(/a/,‘‘); 31 }); 32 var str = " abc "; 33 console.log(str.trim().log2().r()); // 输出链式调用和 bc
学习资源:理解js中的链式调用
时间: 2024-11-05 22:52:34