class 用法 函数变量的作用域
函数变量的作用域
1. 函数体内声明的变量
2. 参数中的变量
没有赋值的 function fn(a){}
赋值的,值不是变量 function fn(a=45){}
赋的值为变量 function fn(a=m){}
参数执行的时候,先给形参赋值,形参也是私有变量,如果给形参赋的值也是变量,先看这个变量是不是私有的(不是针对函数体内,只针对形参,还跟形参的顺序有关),是私有的直接使用,
如果不是私有的,变量找全局的,如果全局没有报错
注意:给形参的赋的变量于形参同名 function fn(a=a) 会出现暂时性死区 因为:形参没有变量提升
class 类的由来
class 的作用:
1. 定义类的
2. 没有变量提升
案例:
class Person{
constructor(){
// constructor 的作用:添加的私有属性 都在这里
}
fn(){
// 默认原型上的属性都在这里
}
static mn(){
// 类上面的方法 需要通过 static 来定义;对象访问不到的方法
}
}
注意: 用类 class 上必须写 constructor
class
1. 在 class 类 添加的属性都是在 原型 prototype 上添加的
2. new 实例的时候,其实就是调用构造函数这个方法
3. 类的本质,就是一个函数
4. 类中的 this 指向实例对象
5. 添加的私有属性都在构造函数中 constructor 添加
6. 每个构造方法都会默认返回实例对象 this ,如果人为改变 return ,返回值返回的基本数据类型,如 字符串、数字等不会改变,如果返回的是引用数据类型,那么return this 就会失效,
变成的你的返回结果
7. 静态的方法,在方法名前面加上 static 关键字,那么这个方法就变成类的私有方法,就得用 类.方法()
继承:extends
子类可以继承父类,使用 extends 关键字
代码块需要使用 super 关键字
constructor 子类构造函数第一行,必须是 super(),super 关键字,在构造函数里面,代表父类构造函数,
如果在原型函数里,super 代表父类的原型
在静态方法中,super 代表父类本身;
案例:
class Person{
constructor(){}
fn(){}
static mn(){}
}
class Son extends Person{
constructor(){
super() //必须调用,代表
}
fn(){
super // 代表父类原型的方法
}
static mn(){
super // 代表父类的私有方法 用 static 定义的方法
}
}
如果 子类构造函数 不使用 super() 那么他的构造函数里的 this 不起作用,子类的 this 要通过父类的构造函数进行塑造;
所以,在子类的 constructor 使用 this 前,一定要调用 super()
supper 既可以充当函数,又可以充当对象;
充当函数时,只能在子类构造函数中使用,且必须放在第一行调用,指向父类构造函数
充当对象中
放在普通函数中,super 指向父类的原型
放在静态方法中,super 执行当前父类本身
只有 super 调用之后,子类才可以使用 this 关键字,指向子类的实例对象;
module (es6 模块设计思想,尽量保持静态化)
es6 使用 export 对外暴露接口
使用 iimport 引入其他模块
import 声明的变量,必须放在 {} 内,变量名必须和暴露的接口名一致;
exprot var a="hello world" (不建议)
var a="hello world"; exprot {a} (建议)
引入接口
import {a} from "文件名"
暴露多个变量,必须加 {}
模块文件暴露什么,引入文件接收什么 (例如:export {a} 为一个对象,那么 import {a} from "文件名" 的 a 就是一个对象)
注意:
export 暴露必须是一个变量,或变量集合
不能直接暴露一个数据,例如:export 12 这种写法就是错的
如果不想让别人知道你暴露的什么接口,我们可以使用 as 关键字
案例:
var a = "hello world";
export {a as ben}; ben 和 a 都 代表了这个字符串
import {ben} from "文件名"
console.log(ben); // hello world
export default 介绍
案例:
a.js
var a="hello world"
export default a;
b.js
import haha from "a.js";
console.log(haha) //hello world;
总结:
export 和 import 时一对,二者后面都必须带 {} ,花括号里面的变量名,保持一致
export default 和 import 也是一对,二者后面不用带 {} ,名字不需要一致;
export default 一次只能对外输出一个
exprot default 本质是将值赋给变量 default ,所以,default 后面不能对变量在次声明;
export default var a x 这种写法错的
export default function fn v 这种写法可以
export default 的本质:
export {a as default} default 可以是任何变量,所以便能实现 export default
class 用法 函数变量的作用域的更多相关文章
- shell中脚本变量和函数变量的作用域
http://blog.csdn.net/ltx19860420/article/details/5570902 1. shell脚本中定义的变量是global的,其作用域从被定义的地方开始,到she ...
- [Z] Shell中脚本变量和函数变量的作用域
在shell中定义函数可以使代码模块化,便于复用代码.不过脚本本身的变量和函数的变量的作用域问题可能令你费解,在这里梳理一下这个问题. (1)Shell脚本中定义的变量是global的,其作用域从被定 ...
- JavaScript 基础(五) 函数 变量和作用域
函数定义和调用 定义函数,在JavaScript中,定义函数的方式如下: function abs(x){ if(x >=0){ return x; }else{ return -x; } } ...
- 18)PHP,可变函数,匿名函数 变量的作用域
(1)可变函数: 可变函数,就是函数名“可变”——其实跟可变变量一样的道理. $str1 = “f1”; //只是一个字符串,内容为”f1” $v1 = $str1(3, 4); //形式上看 ...
- Shell脚本中变量和函数变量的作用域
(1)Shell脚本中定义的变量是global的,其作用域从被定义的地方开始,到shell结束或被显示删除的地方为止.(2)Shell函数定义的变量默认是global的,其作用域从“函数被调用时执行变 ...
- Js中变量的作用域
一.理解函数作用域需要理解以下几点: 1.函数变量的作用域有全局变量和局部变量两种,全局变量写在函数的最前面,局部变量写在函数体内,局部变量省略了var 也就默认成为了全局变量! 2.函数 ...
- Python 学习 第七篇:函数1(定义、调用和变量的作用域)
函数是把一些语句集合在一起的程序结构,用于把复杂的流程细分成不同的组件,能够减少代码的冗余.代码的复用和修改代码的代价. 函数可以0个.1个或多个参数,向函数传递参数,可以控制函数的流程.函数还可以返 ...
- javascript 函数初探 (三)--- javascript 变量的作用域
javascript 变量的作用域: 这是一个至关重要的问题.特别是当我们从别的语言转向javascript时,必须要明白一点,即在javascript中,变量的定义并不是以代码块作为作用域的,而是以 ...
- JavaScript变量的作用域和函数的作用域的区别
变量作用域和函数作用域都涉及到变量值的变化,本文旨在让大家明白他们之间的区别 变量的作用域: 变量的作用域无非就是两种:全局变量和局部变量. Javascript语言的特殊之处,就在于函数内部可以直接 ...
随机推荐
- Codeforces 1220D. Alex and Julian
传送门 首先考虑怎样的集合一定是合法的 发现全部是奇数的集合一定合法,因为每次都是奇数连偶数,偶数连奇数 然后考虑如果集合同时有奇数和偶数是否一定不合法,结论是一定不合法,证明如下: 设某个奇数为 $ ...
- Let和Const的使用
ES2015(ES6) 新增加了两个重要的 JavaScript 关键字: let 和 const. let 声明的变量只在 let 命令所在的代码块内有效,const 声明一个只读的常量,一旦声明, ...
- webstorm 如何去掉下划线
当前webstorm版本:2018.3.5 百度了也没找到解决办法,最终结合了和群友的给的位置,找到了修改地方,只能怪版本迭代太快了,要适应 右上角Effects点掉就可以了
- React Native 底部导航栏
首先安装:npm install react-native-tab-navigator 然后再引入文件中 import TabNavigator from 'react-native-tab ...
- 将div生成图片并下载下来
//文件需要引入html2canvas.js.jquery.js function downLoadImg(){ var element = $(".orgchart"); // ...
- MEWKit:Cryptotheft 的最新武器
By:Yonathan Klijinsma 译者:知道创宇安全服务团队.404区块链安全团队 介绍 当谈到加密货币时,会联想到加密货币巨大的价格波动,交易违约.赎金勒索的情况以及许多不同种类的货币.虚 ...
- java 求数组最大子序列之和
经典问题: 给定一个int[]数组,求其最大子序列之和(条件:数组中不全部都是负数). 最优算法,线性时间复杂度: public static int maxSubSum(int[] a){ int ...
- Linux下单机部署ELK日志收集、分析环境
一.ELK简介 ELK是elastic 公司旗下三款产品ElasticSearch .Logstash .Kibana的首字母组合,主要用于日志收集.分析与报表展示. ELK Stack包含:Elas ...
- PAT Basic 1066 图像过滤 (15 分)
图像过滤是把图像中不重要的像素都染成背景色,使得重要部分被凸显出来.现给定一幅黑白图像,要求你将灰度值位于某指定区间内的所有像素颜色都用一种指定的颜色替换. 输入格式: 输入在第一行给出一幅图像的分辨 ...
- ACM常用之 异或运算的性质。