JS变量作用域与解构赋值
用var变量是有作用域的
变量在函数内部声明时,那么该变量只属于整个函数体,函数外不可调用
当两个不同的函数里,使用了用一个相同的变量名,二者不互相影响,相互独立
遇到嵌套函数时,外部函数不可调用内部函数的变量,而内部函数可调用外部函数变量
当遇到同一变量时,也是同理,“就近原则”
变量提升
JavaScript的函数定义有个特点,它会先扫描整个函数体的语句,把所有申明的变量“提升”到函数顶部
function test(){
var x = 'test, ' + y;
console.log(x);
var y = '2';
}
foo();
返回:
//test, undefined
打印并不会出错,这是因为此时,变量 y 已经被声明,当未被赋值
在引擎里面看到的代码
function test(){
var x;
var y;
x = 'test, ' + y;
console.log(x);
y = '2';
}
基于Javascript特性,我们在函数定义变量时,应该遵守,首先声明所有变量的规则
最常见的做法是用一个var申明函数内部用到的所有变量
function test(){
var x = 1, y = 2, z;
...
}
全局作用域
不在任何函数内定义的变量就具有全局作用域,全局作用域的变量会被绑到window的一个属性上
var course = 'Learn Js';
console.log(course); // 'Learn Js'
console.log(window.course); // 'Learn Js'
我们以前用变量定义函数,同样的,其也会成为全局变量
提升ReferenceError错误,是因为没有该变量
命名空间
为了避免使用了相同全局变量,造成命名冲突
我们把所有的变量和函数全部绑定到一个全局变量(对象)里
//唯一全局变量 myApp
var myApp = {};
//其他变量
myApp.name = 'Job';
myApp.edition = 1.0;
myApp.test = function(){
...
}
局部作用域
变量作用域在函数内部,但for等语句块无法定义其局部的作用域,所有可以被当前函数所调用
function test() {
for (var i = 0; i < 2; i++){
...
}
console.log(i); // 2
}
为了解决类似这样的问题,ES6标准引入了关键字let,功能和var一样,但let可以声明一个块级作用域变量
function test() {
for (let i = 0; i < 2; i++){
...
}
console.log(i); // ReferenceError 该作用域没有此变量
}
常量
在ES6标准之前,无法没有此功能,通常用变量整体大写来表示常量
var EDITION = 1.0;
ES6标准则引入关键字,const来定义常量,const与let一样具有块级作用
const edition = 1.0;
edition; // 1.0
解构赋值
ES6标准引入了解构赋值,可以同时对一组变量进行赋值
什么是解构赋值?
var array = ['Job', 'Steven', 'Ben'];
var x = array[0];
var y = array[1];
var z = array[2];
ES6演示
var [x, y, z] = ['Job', 'Steven', 'Ben'];
console.log('x = ' + x + ', y = ' + y + ', z = ' + z)
// x = Job, y = Steven, z = Ben
也可以选择解构赋值某一个值
var [, , z] = ['Job', 'Steven', 'Ben'];
z; // Ben
同样也可以获取对象属性
var person = {
name: 'Job',
age: 18,
school: 'No.1 school',
email: 'xxx.@xx.com'
};
var {name, age, email} = person;
console.log('name = ' + name + ', age = ' + age + ', email = ' + email);
// name = Job, age = 18, email = xxx.@xx.com
对嵌套的对象属性进行赋值时, 只要保证对应的层次是一致的
var person = {
name: 'Job',
age: 18,
school: 'No.1 school',
email: 'xxx.@xx.com'
address: {
city: 'Earch',
mail: 10001
}
};
var {name, address: {city, street}} = person;
name; // Job
city; // Earch
street; // undefined
解决解析赋值对应不存在问题
var {name, city: test} = person;
name; // Job
test; // Earch
这里的city并非变量,仅仅是把值赋给test
city; // ReferenceError
解构赋值也可以使用默认值
var {name, single = true} = person;
当变量被声明后,解析赋值所被赋值的变量则无效
// 声明变量
var x, y;
// 解构赋值
{x, y} = { name: '小明', x: 100, y: 200};
// 语法错误: SyntaxError
这是因为JavaScript引擎把{开头的语句当作了块处理,于是=不再合法。解决方法是用小括号括起来
({x, y} = { name: '小明', x: 100, y: 200});
这里暂时看不懂
使用场景
交换两个临时变量
var x=1, y=2;
[x, y] = [y, x]
快速获取当前页面域名和路径
var {hostname:main, pathname:path} = location;
JS变量作用域与解构赋值的更多相关文章
- JavaScript学习笔记(八)——变量的作用域与解构赋值
在学习廖雪峰前辈的JavaScript教程中,遇到了一些需要注意的点,因此作为学习笔记列出来,提醒自己注意! 如果大家有需要,欢迎访问前辈的博客https://www.liaoxuefeng.com/ ...
- ES6 (一)变量声明方法 & 解构赋值
就是最新的JavaScript 原来的是var,要求不严格,不能限制修改,函数级 es6要求严格 1.防止重复声明 let 变量=var const 常量 2.控制修改 const常量不能修 ...
- 001-es6变量声明、解构赋值、解构赋值主要用途
一.基本语法 1.1.声明变量的六种方法 参看地址:http://es6.ruanyifeng.com/#docs/let let:局部变量,块级作用域,声明前使用报错 var:全局变量,声明前使用 ...
- ES6知识整理(2)--变量的解构赋值
最近准备在业余空闲时间里一边学习ES6,一边整理相关知识.只有整理过的学习才是有效的学习.也就是学习之后要使用和整理成文,才是真正的学到了... 上一篇是一个试水,现在接上. 变量提升 看了下朋友回复 ...
- ES6学习随笔--字符串模板、解构赋值、对象、循环、函数、Promise、Generrator
在线编译器:babel.github 在nongjs中使用 'use strict' let a = ; 运行node : node --harmony_destructuring xxx.js 代码 ...
- ES6笔记(3)-- 解构赋值
系列文章 -- ES6笔记系列 解构赋值,即对某种结构进行解析,然后将解析出来的值赋值给相关的变量,常见的有数组.对象.字符串的解构赋值等 一.数组的解构赋值 function ids() { ret ...
- ES6解构赋值
前面的话 我们经常定义许多对象和数组,然后有组织地从中提取相关的信息片段.在ES6中添加了可以简化这种任务的新特性:解构.解构是一种打破数据结构,将其拆分为更小部分的过程.本文将详细介绍ES6解构赋值 ...
- ES6 - Note2:解构赋值
ES6的解构赋值就是利用模式匹配从按照一定模式的数组或者对象中提取值赋值给变量. 1.数组的解构赋值 在ES6以前,变量的赋值是直接指定的,以后可以这么来写,如下所示 let [a,b,c] = [1 ...
- ES6-个人学习笔记二--解构赋值
第二期,解构赋值如果能够熟练应用确实是个十分方便的功能,但是过分的依赖和嵌套只会让代码理解和维护起来十分困难,是个体现高逼格的表达式呢~ 1,解构赋值的基础 //定义:es6运行按照一定模式,从数组或 ...
随机推荐
- Linux磁盘管理及LVM讲解(1)
硬盘接口 从整体的角度上,硬盘接口分为IDE.SATA.SCSI和SAS四种,IDE接口硬盘多用于家用产品中,也部分应用于服务器,SCSI接口的硬盘则主要应用于服务器市场,而SAS只在高端服务器上,价 ...
- 我搭建了一套企业级私有Git服务,抗住了每天上万次攻击!
写在前面 事情是这样的,今年疫情期间,我在某云购买了一套服务器,做什么呢?不是用来部署项目,也不是用来搭建网站,而是用来做代码备份和管理.没错,都是我个人的代码,也许你会说,你个人能有多少代码啊?确实 ...
- Window10 上MindSpore(CPU)用LeNet网络训练MNIST
本文是在windows10上安装了CPU版本的Mindspore,并在mindspore的master分支基础上使用LeNet网络训练MNIST数据集,实践已训练成功,此文为记录过程中的出现问题: ( ...
- springboot:druid 404
druid配置是在servlet中添加,所以需要servlet扫描 aplication里添加@ServletComponentScan("com")
- zabbix_server.conf配置文件参数
NodeID: 在amster-child 的分布式架构中,这个ID是唯一标识zabbix node的号码 ListenPort:Trapper 类型Item监听的端口, SourceIP: 在连接其 ...
- MyEclipse中的项目导入到Eclipse中运行的错误解决
之前用的myEclipse,后来把项目导入eclipse发现报错,将MyEclipse中的项目导入到Eclipse中运行,不注意一些细节,会造成无法运行的后果.下面就说说具体操作:导入后出现如下错误: ...
- 微信小程序结合微信公众号进行消息发送
微信小程序结合微信公众号进行消息发送 由于小程序的模板消息已经废弃了,官方让使用订阅消息功能.而订阅消息的使用限制比较大,用户必须得订阅.需要获取用户同意接收消息的权限.用户必须得和小程序有交互的时候 ...
- Centos-当前和过去登入系统用户信息-last
last 获取当前和过去登入系统的用户相关信息,执行last指令的时候会默认读取/var/log/wtmp文件 相关参数 -a 把客户端IP显示到最后一列 -R 不显示客户端IP地址或主机名 -n 显 ...
- Hive中的数据类型以及案例实操
@ 目录 基本数据类型 集合数据类型 案例实操 基本数据类型 对于Hive的String类型相当于数据库的varchar类型,该类型是一个可变的字符串,不过它不能声明其中最多能存储多少个字符,理论上它 ...
- AA.Dapper升级了
AA.Dapper基于dapper进一步封装而成的orm框架,提供增删改查.分页.事务.原生sql的功能,以满足日常的业务开发. 1.Repository层: DapperRepository类包含大 ...