Ajax::prototype 源码解读

2019-06-03 08:36:20刘景俊

  create: function() { 
    return function() { 
      this.initialize.apply(this, arguments); 
    } 
  } 


/** 
 * 创建一个对象,从变量名来思考,本意也许是定义一个抽象类,以后创建新对象都 extend 它。 
 * 但从其后代码的应用来看, Abstract 更多是为了保持命名空间清晰的考虑。 
 * 也就是说,我们可以给 Abstract 这个对象实例添加新的对象定义。 
 * 
 * 从java去理解,就是动态给一个对象创建内部类。 
 */ 
var Abstract = new Object(); 

/** 
 * 获取参数对象的所有属性和方法,有点象多重继承。但是这种继承是动态获得的。 
 * 如: 
 *     var a = new ObjectA(), b = new ObjectB(); 
 *     var c = a.extend(b); 
 * 此时 c 对象同时拥有 a 和 b 对象的属性和方法。但是与多重继承不同的是,c instanceof ObjectB 将返回false。 
 */ 
Object.prototype.extend = function(object) { 
  for (property in object) { 
    this[property] = object[property]; 
  } 
  return this; 


/** 
 * 这个方法很有趣,它封装一个javascript函数对象,返回一个新函数对象,新函数对象的主体和原对象相同,但是bind()方法参数将被用作当前对象的对象。 
 * 也就是说新函数中的 this 引用被改变为参数提供的对象。 
 * 比如: 
 *     <input type="text" id="aaa" value="aaa"> 
 *     <input type="text" id="bbb" value="bbb"> 
 *     ................. 
 *     <script> 
 *         var aaa = document.getElementById("aaa"); 
 *         var bbb = document.getElementById("bbb"); 
 *         aaa.showValue = function() {alert(this.value);} 
 *         aaa.showValue2 = aaa.showValue.bind(bbb); 
 *     </script>