语法构成

JavaScript 的语言核心 ECMAScript.

区分大小写

ECMAScript 中的一切,包括变量、函数名和操作符都是区分大小写的。

例如:artisan和Artisan表示两种不同的变量。


标识符

所谓标识符,就是指变量、函数、属性的名字,或者函数的参数。

标识符可以是下列格式规则组合起来的一或多个字符:

  • 1.第一字符必须是一个字母、下划线(_)或一个美元符号($)。

  • 2.其他字符可以是字母、下划线、美元符号或数字。

  • 3.不能把关键字、保留字、true、false 和 null 作为标识符。


注释

ECMAScript 使用 C 风格的注释,包括单行注释和块级注释。

// 单行注释
/*
* 这是一个多行
* 注释
*/

直接量(字面量literal)

所有直接量(字面量),就是程序中直接显示出来的数据值。

  • 100 //数字字面量

  • ’小工匠’ //字符串字面量

  • false //布尔字面量

  • /js/gi //正则表达式字面量

  • null //对象字面量

在 ECMAScript 第 3 版中,像数组字面量和对象字面量的表达式也是支持的,如下:

  • {x:1, y:2} //对象字面量表达式

  • [1,2,3,4,5] //数组字面量表达式


关键字保留字

ECMAScript-262 描述了一组具有特定用途的关键字,一般用于控制语句的开始或结束 ,或者用于执行特定的操作等。关键字也是语言保留的,不能用作标识符。

ECMAScript 全部关键字:
JavaScript-语法、关键保留字及变量_JS开发


ECMAScript-262 还描述了另一组不能用作标识符的保留字。尽管保留字在 JavaScript中还没有特定的用途,但它们很有可能在将来被用作关键字。

ECMAScript-262 第 3 版定义的全部保留字
JavaScript-语法、关键保留字及变量_JS开发_02


变量

ECMAScript 的变量是松散类型的,所谓松散类型就是用来保存任何类型的数据。定义变量时要使用 var 操作符(var 是关键),后面跟一个变量名(变量名是标识符)。

var artisan;
alert(artisan);

这句话定义了 artisan变量,但没有对它进行初始化(也就是没有给变量赋值)。这时,系统会给它一个特殊的值 – undefined(表示未定义)。

var artisan= '小工匠';
alert(artisan);

所谓变量,就是可以初始化后可以再次改变的量。ECMAScript 属于弱类型(松散类型)的语言,可以同时改变不同类型的量。(PS:虽然可以改变不同类型的量,但这样做对于后期维护带来困难,而且性能也不高,导致成本很高!)

var artisanString= '小工匠';
artisanString = 100;
alert(artisanString);

重复的使用 var 声明一个变量,只不过是一个赋值操作,并不会报错。但这样的操作是比较二的,没有任何必要。

var artison= '小工匠';
var artison= '小小工匠';

还有一种变量不需要前面 var 关键字即可创建变量。这种变量和 var 的变量有一定的区别和作用范围。

artison= '小工匠';

当你想声明多个变量的时候,可以在一行或者多行操作。

var artison= '小工匠'; var age= 100;

而当你每条语句都在不同行的时候,你可以省略分号。(PS:这是 ECMAScript 支持的 ,但绝对是一个非常不好的编程习惯,切记不要)。

var artison= '小工匠'
var age= 100
alert(artison)

可以使用一条语句定义多个变量,只要把每个变量(初始化或者不初始化均可)用逗号分隔开即可,为了可读性,每个变量,最好另起一行,并且第二变量和第一变量对齐(PS:这些都不是必须的)。

var artison= '小工匠',
    age = 28,
    height;