ホームページ >ウェブフロントエンド >jsチュートリアル >JavaScriptの継承方法を詳しく解説(4)
この記事では主にJavaScriptの継承方法を詳しく説明し、主にコードの形で共有しますので、お役に立てれば幸いです。
1. ツール関数
/** * @param {String} className * @param {String/Function} superClass * @param {Function} classImp */ function $class(className, superClass, classImp){ if (superClass === '') superClass = Object; function clazz() { if (typeof this.init == "function") { this.init.apply(this, arguments); } } var p = clazz.prototype = new superClass(); var _super = superClass.prototype; window[className] = clazz; classImp.apply(p, [_super]); }を継承します。 親クラス person
/** * 父类 Person */ $class('Person','',function(){ this.init = function(name){ this.name = name; }; this.getName = function(){ return this.name; }; this.setName = function(name){ this.name = name; } });サブクラス Man
/** * 子类 Man */ $class('Man', Person, function(supr){ this.init = function(name, age){ supr.init.apply(this,[name]); // 该句很重要 this.age = age; }; this.getAge = function(){ return this.age; }; this.setAge = function(age){ this.age = age; }; }); var m = new Man('Jack',25); console.log(m.name); // Jack console.log(m.age); // 25を定義します。 出力から、サブクラス Man が実際に親クラスの属性とメソッドを継承していることがわかります。
以上がJavaScriptの継承方法を詳しく解説(4)の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。