体验js之美第八课-面向对象创建和继承终结篇
概述
到这里我们讲说js面向对象的系列部分的最后一个课程,面向对象必须掌握两个东西一个是对象的创建一个是继承。这节课我们重点说说这两个问题最后我们说下在ES6里面面向对象怎么玩。
1对象的创建
我们第一节课已经就会用了,单体模式,你可以管它叫json我也不想多说就是这个。
var girlFriend = {
//属性:
hair:"long",
eye:"big",
hobby:"travel",
//方法
cook:function(){},
wash:function(){}
};
下面我说一种更普遍的方式,这个大家看到的情况更普遍,我们一直说js的对象和传统对象不一样它是基于原型的,那么看看创建对象方式。
只需要记住一句话,属性放在构造函数里面,方法放在原型上。
好现在我们重新搞一个妹子,用你熟悉的姿势。
//属性放在构造函数里
function Girl (hair,eye,hobby){
this.hair = hair;
this.eye = eye;
this.hobby = hobby;
}
//方法放在原型上
Girl.prototype.cook = function(){};
Girl.prototype.wash = function(){}
var girlFriend = new Girl('long','big','travel');
这样不挺好吗,我们都这样用啊。
这里我就说下,new关键字的由来。
简单的说new关键字并不该出现在js里,或者说并不是技术原因,仅仅是因为为了争取java那部分用户,所以javascript才叫javascript,然后类这一块又使用了new关键字去符合java程序员的习惯,赢得他们的好感,所以new关键字的出现其实是一个市场策略。但是问题来了,javascript基于原型和java这些语言的类跟js根本不是一个概念new怎么用啊?好,我们上例子说明:
//属性放在构造函数里
function Girl (hair,eye,hobby){
this.hair = hair;
this.eye = eye;
this.hobby = hobby;
}
//方法放在原型上
Girl.prototype.cook = function(){};
Girl.prototype.wash = function(){}
var girlFriend = new Girl('long','big','travel');
那new关键字干嘛了?
简单的说做了三件事:
1.执行构造函数(别太担心名词,就当成普通函数就行,一nainai区别都没)
2.在Girl这个构造函数里面,创建一个 空白的Object
3.将 this 指向这个空白的Object
这里使用我并不推荐使用new,为什么?
有人说使用new可能出现的问题是把new忘掉了就会返回undefined,比如我道哥(Douglas Crockford's,JSON的创造者,《javascript语言精髓》的作者,多说一句,《javascript语言精髓》初学者不要看,你会只有两个问题,这个画的是啥,这特么画的又是啥),但是个人认为关键原因不是这个,毕竟修复忘掉的new至少有两种方式,一种大写构造函数方法首字母作为提醒,一种是用函数方法,我这里就不展开说了,毕竟不重要。
关键原因是JavaScript是一种prototypical类型语言,在创建之初,是为了迎合市场的需要,让人们觉得它和Java是类似的,才引入了new关键字。Javascript本应通过它的Prototypical特性来实现实例化和继承,但new关键字让它变得不伦不类。
不废话怎么解决,
一种方式是使用jquery的方式,返回一个含有new 对象的函数,但是这个并没有从本质上改变使用new.
第二种方式彻底抛弃new.
作为一个面向对象编程无非就关心两件事,创建和继承。
那好我们看看创建的时候怎么搞,
第一种方式,单体模式,不用墨迹了。
第二种方式,就不讲了,其实就是jquery那个方式,我们怎么简单怎么来。
单体模式
var girlFriend = {
//属性:
hair:"long",
eye:"big",
hobby:"travel",
//方法
cook:function(){},
wash:function(){}
};
好关键看继承,我们看见你女儿怎么把你女朋友的优良基因继承下来的。
简单的令人发指。
var daughter = Object.create(girlFriend);
完了,确实完了,这就继承完了,以前的改this指向,什么修改原型,去你妹的统统的没了。
我知道你想说啥,我擦嘞,兼容性咋样。好吧,本着授人以鱼不如授人以红烧鱼的精神,大彬哥给你搞一把
Object.prototype.create = Object.prototype.create||function(o){
function F(){}
F.prototype = o;
return new F();
};
好,这样就鸟了,多么蓝的天啊,面向对象的语法就结束了,剩下的就是面向对象的实际案例了,比如组件化开发,后面我们就看看实际库怎么玩的。
体验js之美第八课-面向对象创建和继承终结篇的更多相关文章
- python第三十八课——面向对象(一)
1.面向对象:(思想) 面向:看.关注.瞅 对象:个体.实体.实例.结果单词:object在python中一些皆对象 面向过程:(思想) 面向:看.关注.瞅 过程:经过.经历.从头到尾 使用一些生活中 ...
- 体验javascript之美第五课 五分钟彻底明白 匿名函数自执行和闭包
通过文你将学到: 1.闭包是怎么回事儿? 2.闭包的原理和在jquery中的应用 3.从一到面试题彻底理解闭包和垃圾回收机制 4.闭包在jquery中的应用 概述 经常听到闭包这个词儿,或者匿名函数自 ...
- 快学Scala 第十八课 (trait多继承)
trait多继承: trait的继承并不像类拥有相同的含义!在下面这个例子中,如果还是运用类的继承的思想,那么运行结果将是什么也没有. trait Logged { def log(msg: Stri ...
- Lance老师UI系列教程第八课->新浪新闻SlidingMenu界面的实现
UI系列教程第八课:Lance老师UI系列教程第八课->新浪新闻SlidingMenu界面的实现 今天蓝老师要讲的是关于新浪新闻侧滑界面的实现.先看看原图: 如图所示,这种侧滑效果以另一种方式替 ...
- Python第八课学习
Python第八课学习 www.cnblogs.com/resn/p/5800922.html 1 Ubuntu学习 根 / /: 所有目录都在 /boot : boot配置文件,内核和其他 linu ...
- NeHe OpenGL教程 第四十八课:轨迹球
转自[翻译]NeHe OpenGL 教程 前言 声明,此 NeHe OpenGL教程系列文章由51博客yarin翻译(2010-08-19),本博客为转载并稍加整理与修改.对NeHe的OpenGL管线 ...
- Kali Linux Web 渗透测试视频教程— 第八课 nessus
Kali Linux Web 渗透测试视频教程— 第八课 nessus 文/玄魂 视频课程地址:http://edu.51cto.com/course/course_id-1887.html 目录 n ...
- NeHe OpenGL教程 第三十八课:资源文件
转自[翻译]NeHe OpenGL 教程 前言 声明,此 NeHe OpenGL教程系列文章由51博客yarin翻译(2010-08-19),本博客为转载并稍加整理与修改.对NeHe的OpenGL管线 ...
- NeHe OpenGL教程 第二十八课:贝塞尔曲面
转自[翻译]NeHe OpenGL 教程 前言 声明,此 NeHe OpenGL教程系列文章由51博客yarin翻译(2010-08-19),本博客为转载并稍加整理与修改.对NeHe的OpenGL管线 ...
随机推荐
- Pandas:DataFrame绘制并保存折线图时不打开图形只保存文件
保存图形,用的是plt.savefig函数,只需要在保存图形之后,调用plt.close()关闭画布,就不会显示出来了: data.plot() outfile='image.png' plt.sav ...
- Python脚本生成可执行文件&(恋爱小脚本)
Python脚本生成可执行文件&(恋爱小脚本) 参考文献: http://c.biancheng.net/view/2690.html; https://blog.csdn.net/qq_39 ...
- LeetCode-047-全排列 II
全排列 II 题目描述:给定一个可包含重复数字的序列 nums ,按任意顺序 返回所有不重复的全排列. 示例说明请见LeetCode官网. 来源:力扣(LeetCode) 链接:https://lee ...
- 十进制数转IEE754单精度浮点数以及浮点数转换的python实现
十进制数转IEE754单精度浮点数 理解题目 单精度浮点数:单精度浮点数是用来表示带有小数部分的实数,一般用于科学计算.占用4个字节(32位)存储空间,包括符号位1位,阶码8位,尾数23位.其数值范围 ...
- php 23种设计模式 - 设计模式简介以及分类
一. Introduction[介绍] 设计模式:提供了一种广泛的可重用的方式来解决我们日常编程中常常遇见的问题.设计模式并不一定就是一个类库或者第三方框架,它们更多的表现为一种思想并且广泛地应用在系 ...
- PHP高并发商城秒杀
1.什么是秒杀 秒杀活动是一些购物平台推出的集中人气的活动,一般商品数量很少,价格很便宜,限定开始购买的时间,会在以秒为单位的时间内被购买一空.比如原价千元甚至万元的商品以一元的价格出售,但数量只有一 ...
- Java编程学习笔记(基础篇)
一.Java中的数据类型 1.基本数据类型:四类 八种 byte(1) boolean(1) short(2) char(2) int(4) float(4) long(8) double(8) 2. ...
- linux signal-list
[root@bogon ~]# kill -l 1) SIGHUP 2) SIGINT 3) SIGQUIT 4) SIGILL 5) SIGTRAP 6) SIGABRT 7) SIGBUS 8) ...
- Django基础五之Ajax
Django基础五之Ajax 目录 Django基础五之Ajax 1. Ajax介绍 2. Ajax前后端传值 2.1 方法一HttpResponse直接返回 2.2 方法二使用Json格式返回 2. ...
- 阿里云服务器搭建vulhub靶场
阿里云服务器搭建vulhub靶场 环境 服务器:阿里云服务器 系统:centos7 应用:vulhub 步骤 vulhub需要依赖docker搭建,首先安装docker. 使用以下方法之一: # cu ...