ホームページ > ウェブフロントエンド > jsチュートリアル > JavaScriptでプライベート属性を実装する方法(2)_javascriptスキル

JavaScriptでプライベート属性を実装する方法(2)_javascriptスキル

WBOY
リリース: 2016-05-16 17:11:05
オリジナル
1070 人が閲覧しました

前回の記事で$classというツール関数を書きましたが、今回の記事ではそれを以下のように改良していきます。以下の関数を実装します

1、継承

2. サブクラスが親クラスを継承する場合、親クラスのプライベート属性は継承しません

コードをコピーします コードは次のとおりです:

/**
* @param {String} className
* @param {String/Function} superCls
* @param {Function} classImp
 */
function $class(className, superCls, classImp){
if(superCls === '') superCls = オブジェクト;
function clazz (){
= new superCls(); var _super = superCls.prototype;
window[クラス名] =
classImp.apply; [_super]);
}


最初に親クラスを作成します



コードをコピーします
コードは次のとおりです:/** * 親クラスの人 */
$class('person','',function(){
// プライベート プロパティの年齢
var age;
this.init = function(n, a){
return this.name
};
this.setName = function(name){
this.name =名前;
}
this.getAge = function(){
年齢を返す
};
this.setAge = function(a){
年齢 = a; };
});


人から継承されたサブクラスを作成します




コードをコピーします


コードは次のとおりです:

$class("Man",person, function(supr){
var school;
this.init = function(n, a, s) {
supr.init.apply(this, [n,a]); 学校 = s; } this.getSchool = function(){ 学校を返します。 }; this.setSchool = function(s){ school = s;
});


サブクラス インスタンスを追加します。 >


コードをコピー


コードは次のとおりです:


var m = new Man('tom', 25, 'pku ');
console.log(m.name); // tom は親クラスの共通属性名を継承できます。
console.log(m.age);親クラスのプライベート属性 age を直接使用して
console.log(m.getAge()); // 25 プライベート属性 age は親クラスの public メソッド getAge
console を通じて取得できます。 log(m.school); // 未定義の Man 自身のプライベート属性はドット演算子を介して取得できません
console.log(m.getSchool) ()); // pku はプライベート属性 school
getSchool() メソッド経由
関連ラベル:
ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
最新の問題
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート