JavaScript OOP 思想
JS的核心是对象
{},
new function(){}这种形式也是对象。
http://www.nowamagic.net/librarys/veda/detail/241
整理一些网上的资料,供参考
1.创建对象
1.1 new
用new进行创建对象:
- var user = new Object();
- user.age = 12;//同时为对象添加属性
- user.name = ‘ajun’;
1.2{}
用{}创建对象,如:
- var user = {
- ‘name’:’ajun,
- ‘age’:12
- }
这里同时候为user添加了两个属性分别为:name,age
在以上代码稍加改造,你还可以为一个对象添加一个方法,如:
- var user = {
- ‘name’:’ajun’,
- ‘age’:12
- ‘say’:function(){
- alert(this.name);//this代表当前对象
- }
- }
2.类和构造函数
2.1如何定义
在javascript中,所有的变量和方法都是对象,都可以用做参数相互传递的。
看以下这个方法:
- function User(name,age){
- this.name = name;
- this.age = age;
- this.say = function(){
- alert(this.name+’ say hello!!’);
- }
- }
此时你可以这样理解,User你可以看成一个类的名字,而User()就是这个类得构造方法,这点有点类似于java中的类和构造方法必须同名,在new的时候调用其构造方法,一些初始化操作,可以放在你的构造方法内,这里我们用于初始化name和age属性的值,以下创建User对象的代码:
- var user = new User(‘ajun’ ,24);
- user.say();//ajun say hello!!
在这里解释以下this:
当我们在new对象的时候,实际会调用一个被叫做的call(),将当前对象做为参数传递进行,赋值给this,所以this就是指当前引用对象
3.原型
3.1 prototype
在 JavaScript 中,每个方法都有名为“prototype”的属性,用于引用原型对象,看如下代码:
- function User(){
- this.name = ‘ajun’;
- this.age = 24;
- this.say = function(){
- alert(this.name+’ say hello!!’);
- }
- }
这个User就会有prototype的属性,引用的时候就可以这样 User.prototype 就可以了,当你new User对象的时候,这个对象就会继承来自User. prototype的所有的属性,而User. prototype又继承自Object.prototype的所有的属性,所以你才可以在你对象上调用toString()等方法,其实他都是Object. Prototype的属性,只是被你的对象继承过来了而已,在这里你可以理解为java的类得继承,子类继承父类。
有prototype的概念,我们就可以通过prototype给User添加方法、属性了,这样以后每个user对象都共享方法和属性,而不是每个对象都会有他们的副本了。
- function User(){
- this.name = ‘ajun’;
- this.age = 24;
- }
- User. prototype. say = function(){
- alert(this.name+’ say hello!!’);
- }
- var user = new User();
- user.say();
- var user2 = new User();
- user2.say();
这样我们在new 完一个User对象的时候,调用完这个方法的时候,他还可以供其他方法继续使用。
3.2原型链
每个 JavaScript对象都继承一个原型链,而所有原型都终止于 Object.prototype。注意,迄今为止您看到的这种继承是活动对象之间的继承。它不同于继承的常见概念,后者是指在声明类时类之间的发生的继承。因此,JavaScript 继承动态性更强。它使用简单算法实现这一点,如下所示:当您尝试访问对象的属性/方法时,JavaScript 将检查该属性/方法是否是在该对象中定义的。如果不是,则检查对象的原型。如果还不是,则检查该对象的原型的原型,如此继续,一直检查到 Object.prototype。
JavaScript 动态地解析属性访问和方法调用的方式产生了一些特殊效果:
@ 继承原型对象的对象上可以立即呈现对原型所做的更改,即使是在创建这些对象之后。
@ 如果在对象中定义了属性/方法 X,则该对象的原型中将隐藏同名的属性/方法。例如,
通过在 User.prototype 中定义 toString 方法,可以改写Object.prototype 的 toString 方法。
@ 更改只沿一个方向传递,即从原型到它的派生对象,但不能沿相反方向传递。
例子:
- function User(){
- this.name = ‘ajun’;
- this.age = 24;
- }
- User. prototype. toString = function(){
- alert(this.name+’ say hello!!’);
- }
- var user = new User();
- user. toString ();
此时Object.prototype的toString会被覆盖掉。这样就不会调用Object.prototype的toString了,也就不会输出[Object Object],而输出的是ajun say hello!!了
4.静态属性和方法
有的时候 ,你想不想就像java中那样,通过类直接来操作你的属性和方法,其实在java中这些都是静态属性啦,直接通过类名来引用,在JavaScript中也是可以做的,请看下面的代码:
- function User(){}
- User.age = 12;
- User.name = ‘ajun’;
- User.say = function(){
- return ‘ajun’;
- }
- alert(User.say());
之后就可以用方法名字直接引用你的方法或者属性了,而不用在new一次对象了。
5.私有属性
正常情况下,无法从函数以外访问函数内的本地变量。函数退出之后,由于各种实际原因,该本地变量将永远消失。但是,如果该本地变量被内部函数的闭包捕获,它就会生存下来。这一事实是模拟 JavaScript 私有属性的关键,如:
- function User(name,age){
- this.setName = function(newName){
- name = newName;//name相当于setName的name属性
- };
- this.getName = function(){
- return name;
- }
- this.getAge = function(){
- return age;
- };
- this.setAge = function(newAge){
- age = newAge;
- };
- }
- var user = new User('ajun',24);
- alert(user.getName)//ajun
- user.setName('lisi',12);
- var newName = user.getName();
- alert(newName);//lisi
或者这样也是可以模拟似有属性的,因为name超出其作用域,是不可以被访问的
- function User (name, age) {
- var name;
- this.getName = function() { return name; };
- this.setName = function(newName) {
- name = newName;
- };
- }
- var user = new User ('ajun’,12);
- user. setName('qq');
- alert(p.getName());
注意:你设定的私有属性,是不能被这个方法内的其他公共方法访问的(指的是共享的方法,通过User.prototype定义的方法),这一点和java是不类似的
只能通过在其闭包内拥有这些私有成员的方法来访问私有成员
如:下面的代码 ,是不可以工作的
- User.prototype.somePublicMethod= function() {
- alert(this.getName());
- }
5.命名空间
这里所说的命名空间就相当于我们在java中使用包的概念,这样可以防止方法名冲突,代码如下:
- //命名空间
- var AJUN = {};
- AJUN.Examples = {};
- AJUN.Examples.User=function(){
- this.setName = function(newName){
- name = newName;
- };
- this.getName = function(){
- return name;
- }
- this.getAge = function(){
- return age;
- };
- this.setAge = function(newAge){
- age = newAge;
- };
- }
- var user = new AJUN.Examples.User();
- user.setName('ajun');
- alert(user.getName());
补充:其实用javascript还可以实现类继承等,会用到prototype属性,后续会补上。。。。
http://blog.csdn.net/ajun_studio/article/details/6837182
JavaScript OOP 思想的更多相关文章
- javascript大神修炼记(7)——OOP思想(多态)
读者朋友们大家好,今天我们就接着前面的内容讲,前面我们已经讲到了继承,今天我们就来讲OOP目前最后一个体现,那就是多态,因为javascript语言的灵活性,所以我们是没有办法使用接口的,所以这也给j ...
- javascript大神修炼记(6)——OOP思想(继承)
读者朋友们大家好,我们今天这一讲就接着前面的封装继续讲解,今天就是在前面内容上面的升级,OOP思想中的继承,我们就先来解释一下继承到底是什么意思,我们在什么地方会用到继续. 继承就是,后代继续祖先的一 ...
- javascript大神修炼记(5)——OOP思想(封装)
读者朋友们好,前面我们已经讲解了有关javascript的基础,从今天的内容开始,我们就要开始讲有关封装的内容了,这里,我们就一点一点地接触到OOP(面向对象编程)了,如果作为一门语言使用的程序员连O ...
- OOP思想
OOP思想 读者朋友们大家好,我们今天这一讲就接着前面的封装继续讲解,今天就是在前面内容上面的升级,OOP思想中的继承,我们就先来解释一下继承到底是什么意思,我们在什么地方会用到继续. 继承就是,后代 ...
- JQuery OOP 及 OOP思想的简易理解
在项目维护的时候,看到通篇的function实际上是非常费(痛)劲(苦),个人对于前端也不是特别熟悉,就想着JQuery能否也建立OOP的写法? 目的便于日后代码维护管理,就算不为了自己,日后交接后也 ...
- 拖拽系列二、利用JS面向对象OOP思想实现拖拽封装
接着上一篇拖拽系列一.JavaScript实现简单的拖拽效果这一篇博客将接着对上一节实现代码利用JS面向对象(OOP)思维对上一节代码进行封装; 使其模块化.避免全局函数污染.方便后期维护和调用:写到 ...
- JavaScript OOP 之 this指向
今天给大家分享一个JavaScript OOP中关于分辨this指向对象的小技巧,很实用呦! 我们先来看一段代码: 大家能判断出func();和obj.func();这两句的this指向吗? 首先,我 ...
- 使用JavaScript OOP特性搭建Web应用
最近,我面试了一个有五年 Web 应用程序开发经验的软件开发人员.四年半来她一直在从事 JavaScript 相关的工作,她自认为 JavaScript 技能非常好,但在不久之后我就发现实际上她对 J ...
- OOP思想应该怎样来理解?
https://blog.csdn.net/qq157962718/article/details/50990154 https://www.cnblogs.com/xiaosongluffy/p/5 ...
随机推荐
- iOS学习笔记之Category
iOS学习笔记之Category 写在前面 Category是类别(也称为类目或范畴),使用Category,程序员可以为任何已有的类添加方法.使用类别可以对框架提供的类(无法获取源码,不能直接修改) ...
- ps做gif love教程(转)
先看看效果吧: 这是在写部教程的时候,看到一个由方格组成的心.于是试着用PS做成了动画,然后加入了LOVE四个字母,看起来还可以.但是,有些复杂.复杂倒不是技术上的复杂,是做起来复杂. 来试试吧. 1 ...
- I-frame、B-frame、P-frame及DTS、PTS的关系(转)
基本概念: I frame :帧内编码帧 又称intra picture,I 帧通常是每个 GOP(MPEG 所使用的一种视频压缩技术)的第一个帧,经过适度地压缩,做为随机访问的参考点,可以当成图象. ...
- Linux_系统信息
公司里一些仿真软件得进Linux系统,好奇公司用的什么Linux版本,于是搜罗了几个命令如下: 1 uname - Print system info -a, print all info -s, ...
- Java多线程学习总结--线程概述及创建线程的方式(1)
在Java开发中,多线程是很常用的,用得好的话,可以提高程序的性能. 首先先来看一下线程和进程的区别: 1,一个应用程序就是一个进程,一个进程中有一个或多个线程.一个进程至少要有一个主线程.线程可以看 ...
- 【Python学习笔记】with语句与上下文管理器
with语句 上下文管理器 contextlib模块 参考引用 with语句 with语句时在Python2.6中出现的新语句.在Python2.6以前,要正确的处理涉及到异常的资源管理时,需要使用t ...
- c#中@符号作用
用 @ 符号加在字符串前面表示其中的转义字符“不”被处理. 如果我们写一个文件的路径,例如"D:/文本文件"路径下的text.txt文件,不加@符号的话写法如下: string f ...
- Java之对象池
单例模式是限制了一个类只能有一个实例,对象池模式则是限制一个类实例的个数.对象池类就像是一个对象管理员,它以Static列表(也就是装对象的池子)的形式存存储某个实例数受限的类的实例,每一个实例还要加 ...
- Python基础-函数(function)
这里我们看看Python中函数定义的语法,函数的局部变量,函数的参数,Python中函数的形参可以有默认值,参数的传递是赋值操作,在函数调用时,可以对实参进行打包和解包 1,函数定义 关键字def引 ...
- UVa11997K Smallest Sums(优先队列)
K Smallest Sums You're given k arrays, each array has k integers. There are kk ways to pick exactly ...