《javascript设计模式》学习笔记一:Javascript面向对象程序设计对象成员的定义分析


Posted in Javascript onApril 07, 2020

本文实例讲述了Javascript面向对象程序设计对象成员的定义。分享给大家供大家参考,具体如下:

序:

刚接触javascript的时候,觉得这语言有点儿摸不着门道,感觉这玩意儿太难学了,没什么规范,没什么像样的手册,而且还跟html,dom,css打交道,更觉得一团糟,代码可读性也很差,面向过程的勉强能看懂,看面向对象的代码简直就是杯具,各种括号啊,后来了解ajax,了解了jquery,知道了很多网页特效都是用javascript写的,才慢慢有了好感,来了bd以后写javascript和php一半一半才渐渐发现javascript的强大和灵活,看了《javascript权威指南》和《javascript高级编程》之后发现,正是因为她的灵活,铸就了她的伟大,接下来我会把学习javascript中的一些内容记录下来,一方面加深自己的印象,另一方面也算是分享吧。

1.公有成员

我们都知道,在javascript里,万物皆对象,因此定义一个对象和公有成员最简单不过了:

var obj = {
 aa:"I'm public"
}

但是这个对象只是一个空壳,不论在java还是C++/C#中对象都是有构造函数的,怎么能让定义对象的时候,同时定义他的构造函数呢?在java/C++中,构造函数其实是对象的一个成员函数,但是在javascript中我们要换一种思维,如果仅仅定义构造函数:

var obj = {
 aa:"I'm public",
 _construct:function(){
 }
}

我们在new这个对象的时候,构造函数是不会“自动”执行的,所以想想之前说到的“万物皆对象”,如何让一个对象在定义的时候执行一个函数呢?那就是定义一个函数对象:)

var obj = function(mem1){
 this.aa = mem1;
};

这样我们就定义了一个具有“构造函数”的对象了

2.公有方法

定义公有方法的方式和定义公有成员的方式一样,只不过这个成员是一个函数,而不是一个string或者其他类型的对象

var obj = fucntion(mem1){
 this.a = mem1;
 this.getA = function(){
  return this.a;
 }
};

3.私有成员和私有方法

我们知道虽然javascript中有对象的概念,但是却没有“私有”的概念,也就是说我们不能像java/C++一样使用关键词private来定义一个私有成员,只要是成员,就是公有的,那么怎么实现私有成员呢?我们首先考虑这个问题:什么叫私有成员?私有成员就是在对象的外部不能直接访问的成员,比如对象obj,如果我们能直接引用obj.a那么他就是公有的,如果引用obj._b,提示错误或者抛出异常,那么_b就是私有的。实现私有成员也就是实现在类的外部不能访问他的某种成员,而只能通过他的成员函数访问。在1中已经说了,我们现在定义的是函数对象,那么也就是说要实现在函数的外部不能访问他的某种成员,而只能通过他的成员函数访问。函数的成员函数这叫什么话?我们换一种说法:函数内部定义的函数。那么我们要实现的就是在函数的外部不能访问,但是在函数内部定义的函数能访问的某种变量,如果了解javascript特性的开发人员,应该对黑体的这句话感觉似曾相识,没错,这就是闭包的概念。

关于闭包的概念在这儿就不解释了,这个概念可以当作一个专题来讲了,太复杂了,可以看看《javascript高级编程》或者google之。

有了上面的想法,就可以改造一下上面的对象定义。

var obj = function(){
 //private member
 var _b;
 //public member
 this.a = mem1;
 
 //constructor
 _b = mem2;

 //private method definations
 function _getB(){return _b};

 //public method definations
 this.getA = function(){return this.a;};
 this.getB = function(){return _getB();};
 this.setA = fucntion(){……};
 this.setB = fucntion(){……};
}

由于局部变量_b是在函数作用域定义的,因此在函数对象外部无法访问,同样“局部”函数_getB也是在函数作用域中定义的,也无法在函数对象外部访问,但是同是在函数作用域定义的函数getA和getB由于闭包的作用,即使对象(函数)定义时,对象(函数)的代码执行完了(即离开局部作用域),依然能够访问局部变量(成员)_b和局部变量(函数)_getB,从而实现了私有成员和私有函数。

4.静态变量和静态函数

没错,是“静态变量和静态函数”,当我看到这里的时候也很惊讶,闭包实现私有也就算了,怎么还要搞出来一个静态变量和静态函数?熟悉javascript的都知道原型(prototype)的概念,在我看来,其实原型类似于类属性和类方法,但是他在运行期是可以任意改变的,这里再介绍一下javascript中实现静态变量和静态函数

在私有成员和私有方法中,介绍了可以用闭包来实现将“成员”定义在函数作用域中,从而限制其访问,那么如何实现所有对象共享的成员和函数呢?所谓的所有对象共享,换一种思路其实就是这种成员的作用域和其他成员的作用域不同,还是考虑闭包的概念,我们在私有成员和私有方法中定义的对象,对象定义时他的作用域其实就是整个函数作用域,在函数中定义所有内容在new的时候都会执行一遍,那怎么做才能让对象在new的时候其静态成员和静态函数不再被定义呢?别忘了,我们在定义对象的时候他还是个函数,我们写了这么多函数,为啥没写return呢?因为我们一直把他当对象来用,改把人家当成函数看了吧,如果我们再return一个对象的话,那么在new的时候,就只会new我们return的对象了,因此,在外层函数定义的内容只在定义的时候执行,在new的时候就不再执行了。有人又问了,那我们的对象就不再是外层函数对象了,在他里面定义的内容咋用啊?别忘了“闭包”这个概念,return的函数也是在(外层)函数作用域内定义的函数,他“有权”访问外层函数定义的内容,因此,静态变量和静态函数的定义如下:

var obj = (function(){
 
 //static attribute
 var obj_num = 0;
 //static method
 function add(){obj_num++};
 
 return function(mem1){
  this.a = mem1;
  this.func = function(){};
  
  //blow you can write some constructor codes
 }

})();//最早看到这一行我就头大,现在看起来是多么的艺术啊^_^

通常静态方法的时候都是私有的,如果想定义公有的静态方法,可以加上:

obj.pubmethod = function(){
};

5.常量

什么是常量?常量就是对象中不能改变的量,什么又叫对象中不能改变的量?就是说无论在对象内部还是外部都不能改变的量,私有变量本身在外部无法改变,内部无法改变的话也就是没有一个能改变其值的函数即可^_^

以上便是关于javascript中定义最基础对象的一些方法和技巧了,语言越灵活,留给人们思考的空间也就更广阔。

感兴趣的朋友可以使用在线HTML/CSS/JavaScript代码运行工具:http://tools.3water.com/code/HtmlJsRun测试上述代码运行效果。

希望本文所述对大家JavaScript程序设计有所帮助。

Javascript 相关文章推荐
用js通过url传参把数据从一个页面传到另一个页面
Sep 01 Javascript
基于javascript的COOkie的操作实现只能点一次
Dec 26 Javascript
js进行表单验证实例分析
Feb 10 Javascript
jquery实现点击展开列表同时隐藏其他列表
Aug 10 Javascript
CSS3 3D 技术手把手教你玩转
Sep 02 Javascript
Jquery Easyui自定义下拉框组件使用详解(21)
Dec 31 Javascript
JavaScript之iterable_动力节点Java学院整理
Jun 29 Javascript
vue使用axios实现文件上传进度的实时更新详解
Dec 20 Javascript
详解vue-router 初始化时做了什么
Jun 11 Javascript
深入学习js函数的隐式参数 arguments 和 this
Jun 24 Javascript
微信小程序webview与h5通过postMessage实现实时通讯的实现
Aug 20 Javascript
JS创建自定义对象的六种方法总结
Dec 15 Javascript
详解vue-flickity的fullScreen功能实现
Apr 07 #Javascript
小谈angular ng deploy的实现
Apr 07 #Javascript
简单了解Vue + ElementUI后台管理模板
Apr 07 #Javascript
vue开发中遇到的问题总结
Apr 07 #Javascript
手把手教您实现react异步加载高阶组件
Apr 07 #Javascript
javascript绘制简单钟表效果
Apr 07 #Javascript
js中位数不足自动补位扩展padLeft、padRight实现代码
Apr 06 #Javascript
You might like
PHP函数篇之掌握ord()与chr()函数应用
2011/12/05 PHP
解析PHP无限级分类方法及代码
2013/06/21 PHP
php生成缩略图填充白边(等比缩略图方案)
2013/12/25 PHP
Codeigniter整合Tank Auth权限类库详解
2014/06/12 PHP
Apache PHP MySql安装配置图文教程
2016/08/27 PHP
PHP 验证身份证是否合法的函数
2017/02/09 PHP
CentOS7.0下安装PHP5.6.30服务的教程详解
2018/09/29 PHP
laravel 多图上传及图片的存储例子
2019/10/14 PHP
走出JavaScript初学困境—js初学
2008/12/29 Javascript
nodejs中使用monk访问mongodb
2014/07/06 NodeJs
javascript关于继承的用法汇总
2014/12/20 Javascript
JS实现页面超时后自动跳转到登陆页面
2015/01/19 Javascript
JavaScript中的substr()方法使用详解
2015/06/06 Javascript
基于JQuery实现仿网易邮箱全屏动感滚动插件fullPage
2015/09/20 Javascript
jquery easyui datagrid实现增加,修改,删除方法总结
2016/05/25 Javascript
几种二级联动案例(jQuery\Array\Ajax php)
2016/08/13 Javascript
nodejs简单实现操作arduino
2016/09/25 NodeJs
小程序开发实战:实现九宫格界面的导航的代码实现
2017/01/19 Javascript
深入理解在JS中通过四种设置事件处理程序的方法
2017/03/02 Javascript
使用 UniApp 实现小程序的微信登录功能
2020/06/09 Javascript
JavaScript canvas实现跟随鼠标移动小球
2021/02/09 Javascript
python aiohttp的使用详解
2019/06/20 Python
python中必要的名词解释
2019/11/20 Python
Django app配置多个数据库代码实例
2019/12/17 Python
Python CSS选择器爬取京东网商品信息过程解析
2020/06/01 Python
浅谈python 调用open()打开文件时路径出错的原因
2020/06/05 Python
详解python如何引用包package
2020/06/07 Python
pytorch中的weight-initilzation用法
2020/06/24 Python
python如何调用php文件中的函数详解
2020/12/29 Python
财务务虚会发言材料
2014/10/20 职场文书
2014年出纳工作总结与计划
2014/12/09 职场文书
2015年大学生村官工作总结
2015/04/21 职场文书
2015年工商局个人工作总结
2015/07/23 职场文书
礼貌问候语大全
2015/11/10 职场文书
Nginx 路由转发和反向代理location配置实现
2021/11/11 Servers
详细聊一聊mysql的树形结构存储以及查询
2022/04/05 MySQL