五、语法:
语法(grammar)与词法(syntax)不同。后者强调语言的 运算符、关键字等。而语法定义了此法规则是如何构成可运行的程序代码的。
一)、语句和表达式:
语句(statement)与表达式(expression),举例说明:
var a = 3 * 6;
a = 3 * 6是一个赋值表达式,加上var,就表明是一个声明同时赋值的语句,即语句由一个或多个表达式组成。
1、语句的结果值:
语句都有一个结果值,如果使用控制台,输入语句,默认情况下控制台会显式所执行的最后一条语句的结果值。
或者使用 eval函数(很多语言都有这个函数,用以将字符串视作语句执行,并返回语句结果值)。
var a, b;
a = if (true) {
b = 4 + 38;
};
a; // 42
2、上下文规则:
1)、大括号:
JS中有两种情况会用到{}:
-
对象常量
var a = { foo: bar() };
-
标签
2)、对象解构:
ES6中新加了解构赋值:
function getData() {
// ..
return {
a: 42,
b: "foo"
};
}
var {a, b} = getData();
console.log(a, b); // 42 "foo"
3)、else if:
JS中可以使用else if的原因是,if和else只包含单条语句的时候可以省略代码的{}。
二)、运算符优先级:
利用运算符优先级可以实现逻辑短路,利用逻辑短路可以实现更简洁的类似if else的逻辑表达。
三)、自动分号:
虽然JS有时会为代码行补上缺失的分号,即自动分号插入(Automatic Semicolon Insertion,ASI),但是我们不应该依赖他。
四)、错误:
JS拥有各种类型的运行时错误(TypeError、ReferenceError、SyntaxError等),同时也定义了一些编译时错误(早期错误)。
五)、函数参数:
不要再使用arguments数组。
六)、try..finally:
finally中的代码总是会在try之后执行,如果有catch的话则在catch之后执行。也可以将finally中的代码看作一个回调函数,即无论出现什么情况最后一定会被调用。
如果有finally语句,try中的continue、break、return语句最后还是要执行finally语句,如果finally报错(throw)或return、break,try中的结果会被丢弃。
七)、switch:
switch (a) {
case 2:
// ..
break;
case 42:
// ..
break;
default:
// ..
}
a会与case表达式逐一比较(严格相等,===),如果匹配就执行该case中的代码。