“字面量”即常量,是固定值,不可改变。
字面量有3种:
(1)数值的字面量非常简单,写上去就行了,不需要任何的符号。
alert(886); //886是数字,所以不需要加引号。
(2)字符串的字面量也很简单,但一定要加上引号。可以是单词、句子等。例如:
console.log('886');
console.log('千古壹号,永不止步');
温馨提示:100是数字,"100"是字符串。
(3)布尔字面量举例:
if (true) {
console.log('如果为真,就走这里面的代码);
}
字面量都可以直接使用,但是我们一般不会直接使用字面量。
如果直接使用字面量的话,比较麻烦。比如说,多个地方要用到同一个字面量,还不如事先定义一个变量,用来保存字面量。
变量更方便我们使用,所以在开发中都是通过变量去保存一个字面量,而不会直接使用字面量。
变量:是用于存放数据的容器。我们通过「变量名」获取数据,甚至可以修改数据。
变量还可以用来保存字面量。
本质:变量是程序在内存中申请的一块用来存放数据的空间。
在ES6语法之前,统一使用var
关键字来声明一个变量。比如:
var name; // 声明一个名为 name 的变量
补充:在ES6语法及之后,统一使用 const
、let
关键字来声明一个变量。
name= 'hi'
变量的声明和赋值,举例如下:
var a = 100; // ES5语法
const b = hello; // ES6 语法
let b = world; // ES6 语法
PS:在JavaScript中,永远都是用var来定义变量(在ES6 之前),
有经验的程序员,会把声明和赋值写在一起:
var a = 100; //声明,并且赋值100
console.log(a); //输出100
声明一个变量并赋值, 我们称之为变量的初始化。
一个变量被重新复赋值后,它原有的值就会被覆盖,变量值将以最后一次赋的值为准。
同时声明多个变量时,只需要写一个 var, 多个变量名之间用英文逗号隔开。
var name = 'jack', age = 27, number = 100;
变量建议先声明,再使用。否则可能会报错。具体如下。
写法1、先声明,再赋值:(正常)
var a;
a = 100;
console.log(a); // 打印结果:100
写法2、不声明,只赋值:(正常)
a = 100;
console.log(a); // 打印结果:100
写法3、只声明,不赋值:(注意,打印 undefined)
var a;
console.log(a); // 打印结果:undefined
写法4、不声明,不赋值,直接使用:(会报错)
console.log(a); // 会报错
写法1和写法2虽然都正常,但这两种写法是有区别的
大写字母是可以使用的,并且大小写敏感。也就是说A和a是两个变量。
我们来整理一下变量的命名规范:
标识符:在JS中所有的可以由我们自主命名的都可以称之为标识符。
例如:变量名、函数名、属性名、参数名都是属于标识符。通俗来讲,标识符就是我们写代码时为它们起的名字。
标识符的命名规则和变量的命令规则是一样的。
同样,标识符不能使用语言中保留的关键字及保留字。
关键字:是指 JS 本身已经使用了的单词,不能再用它们充当变量、函数名等标识符。
JS 中的关键字如下:
break、continue、case、default、
if、else、switch、for、in、do、while、
try、catch、finally、throw、
var、void、function、return、new、
this、typeof、instanceof、delete、with、
true、false、null、undefined
保留字:实际上就是预留的“关键字”。意思是现在虽然还不是关键字,但是未来可能会成为关键字,同样不 能使用它们当充当变量名、函数名等标识符。
JS 中的保留字如下:
abstract、boolean、byte、char、class、const、
debugger、double、enum、export、extends、final、float、goto
implements、import、int、interface、long、native、package、
private、protected、public、short、static、super、synchronized、throws、
transient、volatile