ES6 new syntax of let and const (one)
variable declarations : let, const,and block scope
why we redefine the way about declarations?
function scope
var price = 10; //global declaration
function showPrice(){
var price = 12; //local declaration using var
console.log(price); //12
}
showPrice();
console.log(price); //10
The next we can use IIFE to check var variable;
var price = 10;
(function(){
var price = 12;
console.log(price); //12
})();
console.log(price); //10
IIFE: Immediately Invoked Function Expression,意为立即调用的函数表达式,也就是说,声明函数的同时立即调用这个函数。
How to change the scope of var variable?
var price = 10;
if(price){
price = 12;
console.log(price);
}
console.log(price);
The examples demonstrates _ of var.
The example make me confusing.
var price = 10;
function showPrice(){
var price = 12;
console.log('price',price);
}
showPrice();
console.log('showPrice',showPrice());
console.log(price);
the resule is
price 12
price 12
showPrice undefined
10
why have two price?
we add block scope like let and const to solve the problems.
what is block scope?
block scoping means that new scope is created between a pair of { }.
let nbr = 12;
{
let nbr = 40;
}
console.log(nbr)
1.var is bound to function scope
2.let and const are block scope
How to install preview about markdown in sublime?
1.we can use package install to install our plugins
.first use keyboard open the package istall
command+shift+p
IIFE
var price = 12;
if(price){
var price = 10;
console.log(price);
}
console.log(price);
IIFE tell us that the var declarations are bound to the function scope and does not create block scope.
var is bound to function scope, let and const are block scope.
let value = 42;
{
let value = 1000;
}
console.log(value);
let varible only read in the block scope.
const
const declarations is a immutable varible.
const value = 50;
console.log(value);
value = 1000;
const value = 50;
console.log(value);
let value = 1000;
varible hoisting
console.log(host);
var host = 89;
In my heart,it may be console 89;Actualy it is undefiend;
beacuse it is become next code in our browser
var host;
console.log(host);
var host = 89;
If you use let to declate a varible,it is err:
console.log(host);
let host =100;
I'm confusing!
TDZ(Temporal Dead Zone)
You are accessing a varible that's been declared but not yet initialized.
let data = true;
if(true){
console.log(data);
let data;
}
console.log(data);
It's print the value
undefiend
true;
But in the book ,author told me that print
ReferenceError
true
let data = true;
if(true){ //Enter new scope,TDZ starts
//uninitialized bindling for data is created
console.log(data); //ReferenceError
let data;//TDZ ends,'data' is initialized with undefined
}
console.log(data); //true
TDZs helps us ensure that a variable in runtime always have correct value.
if(ture){
console.log(typeof anUndeclaredVariable);
console.log(typeof nrandom);
let random;
}
It is a good practice to always make varible declarations at the top of your scope.
This check is also useful for conditionally creating global varibles using var.
You can check if a global variable exsits by doing something like this:
if(typeof globalVariable === 'undefined'){
var globalVariable = {...};
}
const in object
You can add a property to object of const declaration but you cannot assign
a different value to object.
const obj = {};
obj.key = 42;
console.log(obj.key);
obj = {};
sure,if you really want to you could make the value itself immutable by freezing it.
const obj = Object.freeze({});
obj.key = 42;
console.log(obj);
Object.freeze() is shallow.
ES6 new syntax of let and const (one)的更多相关文章
- JavaScript学习系列5 ---ES6中的var, let 和const
我们都知道JavaScript中的var,在本系列的 JavaScript学习系列2一JavaScript中的变量作用域 中,我们详细阐述了var声明的变量的作用域 文章中提到,JavaScript中 ...
- ES6中不得不说的关键字const
上一节讲了let关键字,它是用来声明一个变量,只在块级作用域起作用.这一节我们来学习ES6新增的另一个关键字const. const 的作用 const是constant(常量)的缩写,const和 ...
- es6学习笔记1 --let以及const
let语句的基本用法: 1.let声明的变量为块级作用域,只在最近的{}里面有效,如果在外部引用就会报错. { let a = 10; var b = "hello" } ale ...
- ES6新特性:let和const的使用
(声明, 本文的所有代码均在node的最新稳定版本v4.4.3中执行的, 如果在浏览器中执行请把JS的运行环境提升为ES6) 以前一直用var定义变量, 现在有了两种新的定义变量的方式, 1: let ...
- es6重点笔记:let,const
一,let 先看代码: var a = []; for (var i = 0; i < 10; i++) { a[i] = function () { console.log(i) }; } a ...
- ES6系列之变量声明let const
ES6也出来好久了,最近闲来无事就想着吧es6做一个系统的总结,巩固自己的知识,丰富一下博客. 为什么叫ES6 实际上是ECMA的一个打的标准,这个标准是在2015年6月发布的,正式的名字实际是es2 ...
- ES6中声明变量 let和const特点
在ES6中我们有两种定义变量的方式:let const let特点: 1.let定义时不会进行变量声明提升 2.变量不允许被重复定义 3.变量不可以被删除 4.在for循环当中用let定义i 循 ...
- es6 入坑笔记(一)---let,const,解构,字符串模板
let 全面取代var 大概相似于C++的定义,一个变量必须得先定义后使用,没有预编译 注意let的作用域,一个{}就是一个作用域,上述规则须在一个作用于内 坑:for(let i =0;i < ...
- ES6基本语法之let和const
1.var可以重复声明 var a = 12; var a = 5; alert(a) //5 2.var无法限制修改 如:PI = 3.1415: 3.var没有块级作用域 { } 像: if(){ ...
随机推荐
- 安装php扩展 ffmpeg-php
环境: CentOS 6.5 PHP5.6 安装前php 已加载GD 模块(yum install php-gd)1.添加ffmpeg和ffmpeg-devel源 cat > /etc/yum. ...
- Java注解(1)-注解基础
注解(Annotation)是在JAVA5中开始引入的,它为在代码中添加信息提供了一种新的方式.注解在一定程度上把元数据与源代码文件结合在一起,正如许多成熟的框架(Spring)所做的那样.那么,注解 ...
- git项目初始化
Command line instructions 1.Git global setup git config --global user.name "99176942"git c ...
- struct2_拦截器知识点.
Struts2拦截器原理: Struts2拦截器的实现原理相对简单,当请求struts2的action时,Struts 2会查找配置文件,并根据其配置实例化相对的拦截器对象,然后串成一个列表,最后一个 ...
- NVisionXRFBXConverter(Beta版)实践课程
一.前言 NVisionXR引擎使用的模型格式为.mesh(具体请看NVisionXR引擎基本介绍:http://www.arvrschool.com/read-7381 ),为了能够将常见的格式转换 ...
- Java基础学习笔记二十一 多线程
多线程介绍 学习多线程之前,我们先要了解几个关于多线程有关的概念.进程:进程指正在运行的程序.确切的来说,当一个程序进入内存运行,即变成一个进程,进程是处于运行过程中的程序,并且具有一定独立功能. 线 ...
- JavaScript(第九天)【正则表达式】
假设用户需要在HTML表单中填写姓名.地址.出生日期等.那么在将表单提交到服务器进一步处理前,JavaScript程序会检查表单以确认用户确实输入了信息并且这些信息是符合要求的. 一.什么是正则表 ...
- C语言第六周博客作业--数据类型
一.PTA实验作业 题目1: 7-6 掉入陷阱的数字 1. 本题PTA提交列表 2.设计思路 定义变量N,i,g=1表示位数,a表示各位数字相加的和,b=0,j,N1,c,d用于储存N do{ for ...
- C语言博客作业—数据类型
一.PTA实验作业 题目1: 1. 本题PTA提交列表 2. 设计思路 (2)if(输入的n为奇数){ for(行数小于n/2+1时){ for(空格数等于n-2*k+1) printf(" ...
- SQL函数返回表的示例-Z
create function [dbo].[GetOperateCustGroup] ( ), ) ) returns @TempTable table (MaxPrice float,MinPri ...