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语言的特殊之处,就在于函数内部可以直接 ...
随机推荐
- php文件上传客户端限制和服务器端限制
客户端限制 1,通过表单隐藏域限制文件上传文件的最大值<input type='hidden' name='MAX_FILE_SIZE' VALUE='字节数' />通过accept属性限 ...
- 主成分分析法详解(PCA)
引用:https://blog.csdn.net/program_developer/article/details/80632779 将n维特征映射到k维上,只保留包含绝大部分方差的维度特征,而忽略 ...
- log4net日志输出配置即输出到文件又输出到visual studio的output窗口
<configuration> <configSections> <section name="log4net" type="log4net ...
- iOS-NSLog发布时取消打印日志
1 选择工程的Target -> Build Settings -> Preprocessor Macros. 如图,默认 Debug项,是“DEBUG=1”. 2 在程序中设置全局宏定义 ...
- fdisk磁盘挂载
1.查看磁盘信息 fdisk –l 2.分区 fdisk /dev/vdb :h 帮助命令 :p 查看 :n 进行分区 e extended 逻辑分区 p primary partition ( ...
- [工具] BurpSuite--Intruder功能
BurpSuite--Intruder功能 0x00 配置说明 intruder是进行爆破的,基本流程是标注请求的爆破参数,然后配置字段,选择爆破方式进行爆破,下面来记录下工具的使用 选中intrud ...
- 可持久化BCJ
BZOJ3674:可持久化并查集加强版 n个集合 m个操作操作:1 a b 合并a,b所在集合2 k 回到第k次操作之后的状态(查询算作操作)3 a b 询问a,b是否属于同一集合,是则输出1否则输出 ...
- ThinkPHP中的SQL结果分析
ThinkPHP中的SQL结果分析 在进行结果判断时需要注意. 一.查询SQL: 可能出现的情况:1.查询成功,返回正常数据.2.查询成功,但是没有数据,返回NULL.3.查询错误,写错关键字.结果: ...
- spring事务配置,声明式事务管理和基于@Transactional注解的使用(转载)
原文地址:http://blog.csdn.net/bao19901210/article/details/41724355 事务管理对于企业应用来说是至关重要的,好使出现异常情况,它也可以保证数据的 ...
- 第二篇:请求库之requests,selenium
requests模块 一.介绍 #介绍:使用requests可以模拟浏览器的请求,比起之前用到的urllib,requests模块的api更加便捷(本质就是封装了urllib3) #注意:reques ...