JavaScript语法

块作用域构造 let 和 const

块级声明用于声明在指定块的作用域之外无法访问的变量,块级作用域存在于:
函数内部;
块中的 { }之间 的区域;

在函数作用域或者全局作用域中通过关键字 var 声明的变量,无论在哪里声明;都会被当成在当前作用域顶部声明的变量,这就是JavaScript的变量提升机制;但是这种变量的提升机制在开发时会给我们带来困扰,所以现在引入了let声明,可想而知,其主要的作用就是声明在块中,不会被提升到全局变量;可以将变量的作用域限制在当前的代码块中;

同时ES6还提供了const 关键字,每一个通过const 关键字声明的变量必须在声明的时候进行初始化;否则就会报错;如果使用const s声明对象,对象本身的绑定不能修改,但对象的属性和值可以修改的;

在全局作用域中使用 var 声明的变量或者对象。将作为浏览器环境中的window对象的属性,这就意味着使用 var 很可能会无意覆盖应该已经存在的全局属性;

在JS中,声明变量的时候单引号和双引号是一样的,注意的点就是JS里面的单引号和双引号可以同时使用,但是要遵循一定的准则。
最外面用了双引号了,那么里面就不能再用双引号了,因为引号是成双对的,浏览器读到一个双引号后,到第2个双引号时才算结束;同理,浏览器读到一个单引号后,必须要读到第二个单引号才算结束,

JS是弱(动态)类型的语言,不关心变量创建时的数据类型,是在运行时才能确定变量的数据类型;

JS 中中括号和大括号使用详解:
一、{ } 大括号,表示定义一个对象,大部分情况下要有成对的属性和值,或是函数。
如:var LangShen = {“Name”:“Langshen”,“AGE”:“28”};
上面声明了一个名为“LangShen”的对象,多个属性或函数用,(逗号)隔开,因为是对象的属性,
所以访问时,应该用.(点)来层层访问:LangShen.Name、LangShen.AGE,当然我们也可以用数组的方式来访问,如:LangShen[“Name”]、LangShen[“AGE”],结果是一样的。
该写法,在JSON数据结构中经常用,除此之外,我们平时写函数组的时候,也经常用到,如:
var LangShen = {
Name = function(){
return “LangShen”;
},
Age = function(){
return “28”;
}
}
调用方式差不多,因为是函数组,所以要加上(),如:alert( LangShen.Name() );
二、[ ]中括号,表示一个数组,也可以理解为一个数组对象。
如:var LangShen = [ “Name”,“LangShen”,“AGE”,“28” ];
很明显,每个值或函数,都是独立的,多个值之间只用,(逗号)隔开,因为是数组对象,所以它等于:
var LangShen = Array( “Name”,“LangShen”,“AGE”,“28” );
访问时,也是和数组一样,alert( LangShen[0] );
三、{ } 和[ ] 一起使用,我们前面说到,{ } 是一个对象,[ ] 是一个数组,我们可以组成一个对象数组,如:
var LangShen = { “Name”:“Langshen”,
“MyWife”:[ “LuLu”,“26” ],
“MySon”:[{“Name”:“Son1”},{“Name”:“Son2”},{“Name”:“Son3”}]
}
从上面的结构来看,是一个对象里面的第一项是个属性,第二项是一个数组,第三个是包含有多个对象的数组。调用起来,也是一层一层访问,对象的属性用.(点)叠加,数组用 [下标] 来访问。
如:alert( LangShen.MySon[1].Name ) ;

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值