创建变量的书写格式
书写格式:关键字 标识符 赋值符号 表达式 分号
例子: var i = 1+2 ;
ES5 var i = 1 + 2;可以重复声明标识符、变量提升(只提升变量的声明,不提升变量的赋值)。
//变量提升 只提升变量的声明,不提升变量的赋值。
//要求:var声明的变量(不包含函数中声明的变量)/给一个为未声明的变量赋值
//即把变量的声明,提升到JS文件的第一行
console.log(i); //undefined
var i = 3;
i = 3 //执行会补关键字var
console.log(i); // 3
console.log(j); //j is not defined
j = 3; //只有执行时才会补关键字,因此报变量未声明的错误。
ES6 let j = 1000; const z = 200;不可以重复声明标识符(不同作用域)。 let是声明变量的,const是声明常量的(基本数据类型)const不能更改数值。
标识符:命名规范
硬性要求:不要以数字开头,可以包含(数字、字母、下划线、美元符号);不许使用关键字、不许使用关键字和保留字;区分大小写(大小写敏感);
软性要求:望闻知意
小驼峰命名法:除第一个单词外,其他单词首字母大写 xiaoGou
大驼峰命名法:所有单词首字母大写 XiaoGou
蛇形走位:xiao_gou
匈牙利命名法:数据类型_变量名 N_num
作用域
功能:变量的使用范围
分类:局部作用域(局部作用中的var声明的变量会自动提升为全局作用域)、全局作用域(全局作用域中声明的变量可以在局部中使用)。
//例子1:
let f74 = 1;
console.log(f74); //1
{
console.log(f74); //1
}
//例子2:
let f74 = 1;
{
let f75 = "A";
console.log(f75); //"A"
console.log(f74); //1
}
console.log(f75); //f75 is not defined
//例子3:
let f74 = 1;
{
let f75 = "A";
console.log(f75); //"A"
f74 = 3; //更该全局f74的数据
console.log(f74); //3
}
console.log(f75); //f75 is not defined
//例子4:
let f74 = 1;
{
let f75 = "A";
console.log(f75); //"A"
let f74 = 3; //不同作用域,可以重复声明变量
console.log(f74); //3
}
console.log(f75); //f75 is not defined
//例子5: 局部作用域中var声明的变量,会自动提升为全局变量
//注:只赋值不加关键字,计算机会自动补var
{
var f75 = "A";
console.log(f75); //"A"
}
console.log(f75); //"A"
//例子6:
{
console.log(f75); //undefined
var f75 = "A";
console.log(f75); //"A"
}
console.log(f75); //"A"
//例子7:由于只有执行时才会补关键字var
因此执行时,还没有补充var,
即使用了未声明的变量(报错)
{
console.log(f75); //f75 is not defined
f75 = "A";
console.log(f75); //"A"
}
console.log(f75); //"A"