JS特权方法定义作用以及与公有方法的区别_javascript技巧
程序员文章站
2022-03-19 20:35:55
...
定义特权方法
在构造函数内部通过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();
小结:特权方法作为构造函数的接口,公有方法可以通过特权方法访问私有属性和方法
在构造函数内部通过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();
小结:特权方法作为构造函数的接口,公有方法可以通过特权方法访问私有属性和方法
推荐阅读
-
js中的数组Array定义与sort方法使用示例_javascript技巧
-
JS类中定义原型方法的两种实现的区别_javascript技巧
-
JS this作用域以及GET传输值过长的问题解决方法_javascript技巧
-
js中的数组Array定义与sort方法使用示例_javascript技巧
-
js中同步与异步处理的方法和区别总结_javascript技巧
-
JS类中定义原型方法的两种实现的区别_javascript技巧
-
JS this作用域以及GET传输值过长的问题解决方法_javascript技巧
-
异步JS框架的作用以及实现方法_javascript技巧
-
window.setInterval()方法的定义和用法及offsetLeft与style.left的区别_javascript技巧
-
window.setInterval()方法的定义和用法及offsetLeft与style.left的区别_javascript技巧