DIV CSS 佈局教程網

 DIV+CSS佈局教程網 >> 網頁腳本 >> JavaScript入門知識 >> 關於JavaScript >> JS特權方法定義作用以及與公有方法的區別
JS特權方法定義作用以及與公有方法的區別
編輯:關於JavaScript     
定義特權方法
在構造函數內部通過this關鍵字定義的的方法,可以被實例化的對象繼承所調用。
復制代碼 代碼如下:
var Student = function(name) {
var _name = name; //私有屬性
//特權方法
this.getName = function() {
return _name;
};
this.setName = function(name) {
_name = name;
};
};
var s1 = new Student('zhangsan');
s1.getName(); //zhangsan

特權方法的作用
特權方法能夠在構造函數外面公開訪問(僅限於實例化的對象),而且還能夠訪問私有成員和方法,因此用來做為對象或者構造函數的接口最合適不過了,通過特權方法我們可以控制公有方法對私有屬性或方法的訪問。 在JS框架的擴展中有很多應用。
特權方法與公有方法的區別
相同點:1. 都可以在構造函數外部公開訪問。2. 都可以訪問公有屬性
不同點:有2點
1. 每個實例都要擁有一份特權方法的副本(除在單例中使用外,需要考慮內存),而公有方法為所有實例共享
復制代碼 代碼如下:
//創建Student對象實例
var s1 = new Student('zhangsan');
var s2 = new Student('lisi');
//兩實例的特權方法的引用不相同, 說明在對象實例化的時特權方法被重新創建
console.log(s1.getName === s2.getName); //false

2. 特權方法可以訪問私有屬性和方法,而公有方法不能。
復制代碼 代碼如下:
//為Student創建公有方法
//公有方法不能訪問私有屬性
Student.prototype.myMethod = function() {
console.log(_name); //ReferenceError: _name is not defined
};
s1.myMethod();

小結:特權方法作為構造函數的接口,公有方法可以通過特權方法訪問私有屬性和方法
XML學習教程| jQuery入門知識| AJAX入門| Dreamweaver教程| Fireworks入門知識| SEO技巧| SEO優化集錦|
Copyright © DIV+CSS佈局教程網 All Rights Reserved