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语言的特殊之处,就在于函数内部可以直接 ...
随机推荐
- 5.jQuery之栏切换
<style> * { margin: 0; padding: 0; } li { list-style-type: none; } .tab { width: 978px; margin ...
- java中的集合类详情解析以及集合和数组的区别
数组和链表 数组:所谓数组就是相同数据类型的元素按照一定顺序排列的集合. 它的存储区间是连续的,占用内存严重,所以空间复杂度很大,为o(n),但是数组的二分查找时间复杂度很小为o(1). 特点是大小固 ...
- 初探CSS -3 语法
CSS 语法 实例 <!DOCTYPE html> <html> <head> <meta charset="utf-8"> < ...
- java 返回输入中出现次数最多的字符串
举例输入: abc abc de de de fghi fghi 应该返回: de 代码: static List<String> func(String str) { String[] ...
- 9- 基于6U VPX的 XC7VX690T+C6678的双FMC接口雷达通信处理板 C6678板卡
基于6U VPX的 XC7VX690T+C6678的双FMC接口雷达通信处理板 一.板卡概述 高性能VPX信号处理板基于标准6U VPX架构,提供两个标准FMC插槽,适用于电子对抗或雷达信号等领域 ...
- tensorflow 学习教程
tensorflow 学习手册 tensorflow 学习手册1:https://cloud.tencent.com/developer/section/1475687 tensorflow 学习手册 ...
- w、who、last、lastbon、lastlog显示登录命令用法
一.w 显示已登录用户信息和用户正在执行命令 1.命令功能 w可以显示已登录系统的用户,并显示用户正在执行的命令 2.语法格式 w option user 选项说明 选项 选项说明 -h 不显示前两行 ...
- visual studio密钥
企业版:NJVYC-BMHX2-G77MM-4XJMR-6Q8QF 专业版:KBJFW-NXHK6-W4WJM-CRMQB-G3CDH
- api权限管理系统与前后端分离实践
https://segmentfault.com/a/1190000014368885
- 软件的三大类型-单机类型、BS类型、CS类型
单机类型:最开始的软件就是那些不需要联网的单机软件. CS类型:有的程序需要统一管理软件中使用的数据, 所以就将保存数据的数据库统一存放在一台主机中, 所有的用户在需要数据时都要从主机获取, 这时就分 ...