2.ES6引进的新特性——类Class
为什么?
ES6中引入了类,类在java/c++等面向对象的编程语言常见,JS引入类是为了在日后使用js开发大型的应用程序,类本质是语法糖(语法上更加人性化)
以前写一个类
function User(name, age){
this.name = name;
this.age = age;
}
// 静态方法
User.getClassName = function () {
return 'User'
};
// 为类添加公用方法,在原型对象上加
User.prototype.changeName = function (name) {
this.name = name
}
User.prototype.changeAge = function (age) {
this.age = age
}
// 为类添加取值函数与存值函数(都要写到原型对象上去)
Object.defineProperty(User.prtotype, 'info', {
get(){
return 'name:' + this.name + ' | age:' + this.age;
}
});
// 新建一个子类
function Manager(name, age, password){
User.call(this,name,age); // 也可以User.apply(this, arguments),意思是调用父类的构造函数,从而达到继承父类属性的效果,注意,只能继承父类实例属性,而继承不了父类的方法
this.password = password;
}
// 继承静态方法
Manager._proto_ = User;
// 继承prototype方法(继承父类方法)
Manager.prototype = User.prototype; // 也可以Manager.prototype = new User()
// 添加新方法
Manager.prototype.changePassword = function(pwd){
this.password = password;
};
// 验证是否能继承
var manager = new Manager('kkk', 22, '123');
manager.changeName('lighter');
console.log(manager.name) // 输出 lighter
console.log(manager.info); // 输出 name:lighter | age:22
可以看出,以前ES5写一个类,虽然可以实现类的继承,但是很不优雅--!
ES6优雅写类
我们来注释上面的代码,一段一段地看它们又什么区别
//function User(name, age){
// this.name = name;
// this.age = age;
//}
class User{
constructor(name, age){
this.name = name;
this.age = age;
}
//// 静态方法
//User.getClassName = function () {
// return 'User'
//};
// 静态方法
User.getClassName = function () {
return 'User';
}
//// 为类添加公用方法,在原型对象上加
//User.prototype.changeName = function (name) {
// this.name = name
//}
//User.prototype.changeAge = function (age) {
// this.age = age
//}
// 为类添加公用方法,在原型对象上加
changeName(name) {
this.name = name
}
changeAge(age) {
this.age= age
}
//// 为类添加取值函数与存值函数(都要写到原型对象上去)
//Object.defineProperty(User.prtotype, 'info', {
// get(){
// return 'name:' + this.name + ' | age:' + this.age;
// }
//});
// 为类添加取值函数与存值函数(都要写到原型对象上去)
get info() {
return 'name:' + this.name + ' | age:' + this.age;
}
}
// 新建一个子类
//function Manager(name, age, password){
// User.call(this,name,age);
// this.password = password;
//}
//// 继承静态方法,原型链就是实力对象_proto_属性
//Manager._proto_ = User;
//// 继承prototype方法
//Manager.prototype = User.prototype;
class Manager extends User{
constructor(name, age, password){
super(name,age);
this.password = password;
}
//// 添加新方法
//Manager.prototype.changePassword = function(pwd){
// this.password = password;
//};
changePassword(password){
this.password = password
}
}
// 然后下面的用法都是一样的。
// 验证是否能继承
var manager = new Manager('kkk', 22, '123');
manager.changeName('lighter');
console.log(manager.name) // 输出 lighter
console.log(manager.info); // 输出 name:lighter | age:22
语法糖
注意,例如上面写的class 等概念,就是语法糖,它方便了我们写代码,使得代码更加地简洁,无论是class User ,还是class Manager,它们本质都是function
console.log(typeof User, typeof Manager); //输出 function function
简写继承
class I extends User {
}
var me = new I('psg', 23);
console.log(me);
//不报错,输出 I {name: 'psg', age: 23}
上面继承没加构造函数constructor,但是内部默认会加,上面的代码会变成下面这个样子:
class I extends User{
constructor(...arg){
super(...arg);
}
}
总结ES6继承的重点
1.继承时候,如果手写构造函数,那么在constructor块里面,第一行写super(....),因为它要先创建父类的对象,然后所有的方法(上面的changePassword)、属性(上面的password)都会加到父类创建的对象上。
2.使用super可以改变父类的方法,例如上面的Manager类,它继承User父类,现在我想改变从父类中继承的info方法,我加一点东西,使我Manager有别于父类,但是我还是调用同样父类方法的名字,这时我可以这样写:
class Manager extends User{
constructor(name, age, password){
super(name,age);
this.password = password;
}
//// 添加新方法
//Manager.prototype.changePassword = function(pwd){
// this.password = password;
//};
changePassword(password){
this.password = password
}
//使用super改写父类的方法
get info() {
var info = super.info; // 注意!!这里的info没有()
console.log(info);
return info + '--new'
}
}
var manager = new Manager('kkk', 22, '123');
console.log(manager.info);
// 输出 name:lighter | age:22
// 输出 name:lighter | age:22---new
创建立即执行的类
'use strict'
let user = new class User{
constructor(name){
this.name = name;
}
}('psg'); console.log(user); //输出 User {name: 'psg'}
不被提升
'use strict'
var user = new User();
class User{
constructor(name){
this.name = name;
}
}
console.log(user);
//ReferenceError: User is not defined
-----完-----
2.ES6引进的新特性——类Class的更多相关文章
- 前端笔记之ES678&Webpack&Babel(中)对象|字符串|数组的扩展&函数新特性&类
一.对象的扩展 1.1对象属性名表达式 ES6可以在JSON中使用[]包裹一个key的名字.此时这个key将用表达式作为属性名(被当做变量求值),这个key值必须是字符串. var a = 'name ...
- ES6 主要的新特性
本文基于lukehoban/es6features ,同时参考了大量博客资料,具体见文末引用. ES6(ECMAScript 6)是即将到来的新版本JavaScript语言的标准,代号harmony( ...
- ES6语法的新特性
ES6 就是ECMAScript 6是新版本JavaScript语言的标准.虽然目前已经更新到ES7,但是很多浏览器还不知处ES7语法,该标准仍在更新中,但目前部门网站都指出ES6的语法.目前ES6也 ...
- ES6的十个新特性
这里只讲 ES6比较突出的特性,因为只能挑出十个,所以其他特性请参考官方文档: /** * Created by zhangsong on 16/5/20. */// ***********Nu ...
- 深入浅出:了解JavaScript的ES6、ES7新特性
参照阮一峰博客:http://es6.ruanyifeng.com/#README es6常见题:https://blog.csdn.net/qq_39207948/article/details/8 ...
- [js高手之路] es6系列教程 - 新的类语法实战选项卡
其实es6的面向对象很多原理和机制还是ES5的,只不过把语法改成类似php和java老牌后端语言中的面向对象语法. 一.用es6封装一个基本的类 class Person{ constructor( ...
- ES6中常用新特性讲解
1.不一样的变量声明:const和let ES6推荐使用let声明局部变量,相比之前的var(无论声明在何处,都会被视为声明在函数的最顶部) let和var声明的区别: var x = '全局变量'; ...
- 003.ES2015和ES2016新特性--类.md
JavaScript使用的是基于原型的OO模型,用对象字面量或者函数来实例化对象,用原型链来实现继承. 这样对于数据传统C++.Java的OO范式的开发者来说,会感到比较困惑,于是从ES2015开始逐 ...
- 关于ES6的一些新特性的学习
一.关于变量 ES5 1.只有全局作用域变量和函数作用域变量 2.“变量提升”(当程序进入一个新的函数时,会将该函数中所有的变量的声明放在函数开始的位置.仅仅会提升变量的声明,不会提升变量的赋值) E ...
随机推荐
- 【深度学习】安装TensorFlow-GPU
1.Windows版 准备 干净的系统,没有安装过Python,有的话就卸载了. 另外我的系统安装了VS2015 VS2017(这里我不知道是不是必备的). 现在TensorFlow和cuda以及cu ...
- media 标签解释
一:常用标签这句话是自动设置缩放,然而,它并不能完全适应所有的手机,并且你在用浏览器手机模式调试的时候可能正常,但是换到真实的手机端其实是不正常的.所以我们还要进行改动. <meta name= ...
- 如何理解Unity组件化开发模式
Unity的开发模式核心:节点和组件,组件可以加载到任何节点上,每个组件都有 gameobject 属性,可以通过这个属性获取到该节点,即游戏物体. 也就是说游戏物体由节点和组件构成,每个组件表示物体 ...
- anemometer安装
1.背景介绍:nginx:1.9.3 安装路径/data/nginxphp:5.5.27 安装路径 /data/phpmysql:5.7.18 安装路径/usr/local/mysql软件下载目录 / ...
- ubuntu安装苹果Windows以及微软雅黑consolas字体
ubuntu安装苹果Windows以及微软雅黑consolas字体 ubuntu安装苹果字体 wget http://drive.noobslab.com/data/Mac/macfonts.zip ...
- template模板的使用方法
模板 WXML提供模板(template),可以在模板中定义代码片段,然后在不同的地方调用. 定义模板 使用name属性,作为模板的名字.然后在<template/>内定义代码片段 使用模 ...
- qscoj 喵哈哈村的打印机游戏 区间dp
点这里去看题 区间dp ,dp[l][r][d]代表从l到r的区间底色为d,具体看代码 第一次见到区间dp...两个小时对着敲了五遍终于自己敲懂了一遍ac #include<bits/stdc+ ...
- ubuntu16 gitlab的简单安装
1.安装好ubuntu的ssh服务,使用xshell登录虚拟机 2.下载安装包: wget -c https://downloads-packages.s3.amazonaws.com/ubuntu ...
- Leetcode35 Search Insert Position 解题思路(python)
本人编程小白,如果有写的不对.或者能更完善的地方请个位批评指正! 这个是leetcode的第35题,这道题的tag是数组,python里面叫list,需要用到二分搜索法 35. Search Inse ...
- autotrace执行计划中,统计信息详解
全表扫描是怎么扫描的? oracle最小的存储单位是block 物理上连续的block组成了extent(也就是说一个区中的所有块在物理上是连续的) 很多个extent组成了segment(一个seg ...