zoukankan      html  css  js  c++  java
  • John Resig 简单的JavaScript继承实现

    源码:

    (function(){
      var initializing = false, fnTest = /xyz/.test(function(){xyz;}) ? /_super/ : /.*/;
     
      // The base Class implementation (does nothing)
      this.Class = function(){};
       
      // Create a new Class that inherits from this class
      Class.extend = function(prop) {
        var _super = this.prototype;
         
        // Instantiate a base class (but only create the instance,
        // don't run the init constructor)
        initializing = true;
        var prototype = new this();
        initializing = false;
         
        // Copy the properties over onto the new prototype
        for (var name in prop) {
          // Check if we're overwriting an existing function
          prototype[name] = typeof prop[name] == "function" && 
            typeof _super[name] == "function" && fnTest.test(prop[name]) ?
            (function(name, fn){
              return function() {
                var tmp = this._super;
                 
                // Add a new ._super() method that is the same method
                // but on the super-class
                this._super = _super[name];
                 
                // The method only need to be bound temporarily, so we
                // remove it when we're done executing
                var ret = fn.apply(this, arguments);        
                this._super = tmp;
                 
                return ret;
              };
            })(name, prop[name]) :
            prop[name];
        }
         
        // The dummy class constructor
        function Class() {
          // All construction is actually done in the init method
          if ( !initializing && this.init )
            this.init.apply(this, arguments);
        }
         
        // Populate our constructed prototype object
        Class.prototype = prototype;
         
        // Enforce the constructor to be what we expect
        Class.prototype.constructor = Class;
     
        // And make this class extendable
        Class.extend = arguments.callee;
         
        return Class;
      };
    })();

    原文链接: https://johnresig.com/blog/simple-javascript-inheritance/#postcomment

  • 相关阅读:
    NumPy:数组计算
    Matplotlib模块:绘图和可视化
    量化投资与Python
    vue-cli脚手架(框架)
    vue 之webpack打包工具的使用
    vue之node.js的简单介绍
    es6简单介绍
    ECMAScript 6 入门
    爬虫框架之Scrapy
    angular5使用httpclient时解决跨域问题
  • 原文地址:https://www.cnblogs.com/Red-ButterFly/p/7872684.html
Copyright © 2011-2022 走看看