前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >[转]JS私有化的实现——稳妥构造函数

[转]JS私有化的实现——稳妥构造函数

作者头像
就只是小茗
发布2018-12-07 12:18:28
1.1K0
发布2018-12-07 12:18:28
举报
文章被收录于专栏:一个小程序员的成长笔记

所谓稳妥对象, 指的是没有公共属性, 而且其方法也不引用this的对象。稳妥对象函数遵循与寄生构造函数类似的模式, 但有两点不同: 一是新创建对象的实例方法不引用this; 二是不使用new操作符调用构造函数。 最近在浏览博客时发现很多人好像理解错这个稳妥构造函数了, 这个函数与在《javascript 高级程序设计》中提到的其他构造函数的一大特点在于可以利用js作用域实现私有变量化。

代码语言:javascript
复制
 1 function Process (nameF) {
 2     var o = new Object();
 3     var name = nameF;//1
 4     o.sayName = function(){
 5         alert(name);//2
 6     };
 7     return o;
 8 }
 9 
10 var friend = Process('Nick');
11 friend.sayName();  //"Nick"
12 console.log(friend.name);//undefined//3

注意: (以下3点) 1. 在稳妥构造函数中变量不能挂到要返回的对象o中 2. 在稳妥构造函数中的自定义函数操作元素时使用不要用this 3. 在函数外部使用稳妥构造函数时不用new。

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2018-11-07 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档