Web/04-JavaScript基础/02-变量.md

280 lines
7.0 KiB
JavaScript
Raw Normal View History

2018-12-29 12:53:20 +08:00
2018-10-02 22:10:26 +08:00
## 字面量数字和字符串
字面量**常量**是固定值不可改变看见什么它就是什么
2019-12-12 15:04:44 +08:00
字面量有3种
- 数字
- 字符串
- 布尔字面量
2018-10-02 22:10:26 +08:00
2020-04-20 10:16:01 +08:00
1数值的字面量非常简单写上去就行不需要任何的符号例如
2018-10-02 22:10:26 +08:00
```javascript
2019-12-04 16:14:08 +08:00
alert(886); //886是数字所以不需要加引号。
2018-10-02 22:10:26 +08:00
```
2019-12-11 18:16:28 +08:00
2字符串的字面量也很简单但一定要加上引号可以是单词句子等例如
```javascript
console.log('886');
console.log('千古壹号,永不止步');
```
2018-10-02 22:10:26 +08:00
温馨提示100是数字"100"是字符串
2019-12-12 15:04:44 +08:00
3布尔字面量举例
```javascript
if (true) {
console.log('如果为真就走这里面的代码);
}
```
2018-10-02 22:10:26 +08:00
### 总结
字面量都可以直接使用但是我们一般不会直接使用字面量
2019-12-11 18:16:28 +08:00
如果直接使用字面量的话比较麻烦比如说多个地方要用到同一个字面量还不如事先定义一个变量用来保存字面量
2018-10-02 22:10:26 +08:00
2019-12-04 16:14:08 +08:00
变量更方便我们使用所以在开发中都是通过变量去保存一个字面量而不会直接使用字面量
2018-10-02 22:10:26 +08:00
2019-12-11 18:16:28 +08:00
## 变量的概念
2018-10-02 22:10:26 +08:00
2019-12-12 15:04:44 +08:00
**变量**是用于存放数据的容器我们通过变量名获取数据甚至可以修改数据
2018-10-02 22:10:26 +08:00
2019-12-11 18:16:28 +08:00
变量还可以用来保存字面量
2018-10-02 22:10:26 +08:00
2019-12-11 18:16:28 +08:00
**本质**变量是程序在内存中申请的一块用来存放数据的空间
2018-10-02 22:10:26 +08:00
2019-12-11 18:16:28 +08:00
## 变量的声明和赋值
2019-12-04 22:54:48 +08:00
2019-12-11 18:16:28 +08:00
### 变量的声明变量的定义
2019-12-12 15:04:44 +08:00
在ES6语法之前统一使用`var`关键字来声明一个变量比如
2019-12-11 18:16:28 +08:00
```javascript
var name; // 生命一个名为 name 的变量
```
2019-12-12 15:04:44 +08:00
补充在ES6语法及之后统一使用 `const``let`关键字来声明一个变量这个以后再讲
2019-12-11 18:16:28 +08:00
### 变量的赋值
变量的赋值
```javascript
name= '千古壹号'
```
2018-10-02 22:10:26 +08:00
2019-12-11 18:16:28 +08:00
变量的声明和赋值举例如下
2018-10-02 22:10:26 +08:00
```javascript
2019-12-11 18:16:28 +08:00
var a = 100; // ES5语法
2019-12-04 22:54:48 +08:00
2019-12-11 18:16:28 +08:00
const b = hello; // ES6 语法
let b = world; // ES6 语法
2018-10-02 22:10:26 +08:00
```
如下图所示
![](http://img.smyhvae.com/20180116_2020.png)
var是英语variant变量的缩写后面要加一个空格空格后面的东西就是变量名
2019-12-11 18:16:28 +08:00
- 定义变量var就是一个**关键字**用来定义变量所谓关键字就是有特殊功能的单词
2018-10-02 22:10:26 +08:00
- 变量的赋值等号表示**赋值**将等号右边的值赋给左边的变量
- 变量名我们可以给变量任意的取名字
PS**在JavaScript中永远都是用var来定义变量**在ES6 之前这和CJava等语言不同
2019-12-11 18:16:28 +08:00
### 变量的初始化
有经验的程序员会把声明和赋值写在一起
2018-10-02 22:10:26 +08:00
2019-12-11 18:16:28 +08:00
```javascript
var a = 100; //声明并且赋值100
console.log(a); //输出100
2018-10-02 22:10:26 +08:00
```
2019-12-11 18:16:28 +08:00
声明一个变量并赋值 我们称之为**变量的初始化**
2018-10-02 22:10:26 +08:00
2019-12-11 19:59:12 +08:00
## 变量声明和赋值的补充
2019-12-11 18:16:28 +08:00
2019-12-11 19:59:12 +08:00
### 修改变量的值
2018-10-02 22:10:26 +08:00
2019-12-11 18:16:28 +08:00
一个变量被重新复赋值后它原有的值就会被覆盖变量值将以最后一次赋的值为准
举例
2018-10-02 22:10:26 +08:00
```javascript
2019-12-11 18:16:28 +08:00
var a = 100;
a = 110;
console.log(a); // 打印结果110。因为 110 覆盖了 100
```
### 同时声明多个变量
同时声明多个变量时只需要写一个 var 多个变量名之间用英文逗号隔开
举例
```javascript
var name = '千古壹号', age = 27, number = 100;
2018-10-02 22:10:26 +08:00
```
2019-12-11 19:59:12 +08:00
### 变量声明的几种特殊情况
2019-12-11 18:16:28 +08:00
变量建议先声明再使用否则可能会报错具体如下
**写法1**先声明再赋值正常
2018-10-02 22:10:26 +08:00
```javascript
2019-12-11 18:16:28 +08:00
var a;
a = 100;
console.log(a); // 打印结果100
```
**写法2**不声明只赋值正常
```javascript
a = 100;
console.log(a); // 打印结果100
```
**写法3**只声明不赋值注意打印 undefined
```javascript
var a;
console.log(a); // 打印结果undefined
2018-10-02 22:10:26 +08:00
```
2019-12-11 18:16:28 +08:00
**写法4**不声明不赋值直接使用会报错
```javascript
console.log(a); // 会报错
```
控制台会报错
![](http://img.smyhvae.com/20180116_2040.png)
**补充**写法1和写法2虽然都正常但这两种写法是有区别的等以后学习了变量提升的概念就明白了大多数情况下我们都是采用的写法1
## 变量的命名规范
2018-10-02 22:10:26 +08:00
大写字母是可以使用的并且大小写敏感也就是说A和a是两个变量
```javascript
var A = 250; //变量1
var a = 888; //变量2
```
2019-12-11 19:59:12 +08:00
我们来整理一下**变量的命名规范**
2018-10-02 22:10:26 +08:00
2019-12-11 19:59:12 +08:00
- 只能由字母(A-Za-z)数字(0-9)下划线(_)美元符( $ )组成
2018-10-02 22:10:26 +08:00
2019-12-11 19:59:12 +08:00
- 不能以数字开头也就是说必须以字母(A-Za-z)下划线(_)或者美元符( $ )开头变量名中不允许出现空格
2018-10-02 22:10:26 +08:00
2019-12-11 19:59:12 +08:00
- 不用使用 JS 语言中保留的关键字保留字作为变量名
2018-10-02 22:10:26 +08:00
2019-12-11 19:59:12 +08:00
- 建议用驼峰命名规则比如getElementByIdmatherAndFatheraaaOrBbbAndCcc
2018-10-02 22:10:26 +08:00
2019-12-11 19:59:12 +08:00
- 变量名会区分大小写(javascript 是区分大小写的语言)
2018-10-02 22:10:26 +08:00
2019-12-11 19:59:12 +08:00
- 变量名长度不能超过255个字符
2018-10-02 22:10:26 +08:00
2019-12-11 19:59:12 +08:00
- 汉语可以作为变量名但是不建议使用因为 low
## 标识符关键字保留字
### 标识符
2018-10-02 22:10:26 +08:00
**标识符**在JS中所有的可以由我们**自主命名**的都可以称之为标识符
2018-10-02 22:10:26 +08:00
2019-12-12 16:39:36 +08:00
例如变量名函数名属性名参数名都是属于标识符通俗来讲标识符就是我们写代码时为它们起的名字
2018-10-02 22:10:26 +08:00
**标识符的命名规则**和变量的命令规则是一样的看上面一段就可以了
2019-12-12 16:39:36 +08:00
同样标识符不能使用语言中保留的**关键字****保留字**如下
2019-12-11 19:59:12 +08:00
### 关键字
2018-10-02 22:10:26 +08:00
2019-12-12 16:39:36 +08:00
**关键字**是指 JS 本身已经使用了的单词不能再用它们充当变量函数名等标识符
JS 中的关键字如下
```
breakcontinuecasedefault
ifelseswitchforindowhile
trycatchfinallythrow
varvoidfunctionreturnnew
thistypeofinstanceofdeletewith
truefalsenullundefined
```
2018-10-02 22:10:26 +08:00
2019-12-11 19:59:12 +08:00
### 保留字
2018-10-02 22:10:26 +08:00
2019-12-12 16:39:36 +08:00
**保留字**实际上就是预留的关键字意思是现在虽然还不是关键字但是未来可能会成为关键字同样不
能使用它们当充当变量名函数名等标识符
JS 中的保留字如下
2018-10-02 22:10:26 +08:00
```
2019-12-11 19:59:12 +08:00
abstractbooleanbytecharclassconst
2018-10-02 22:10:26 +08:00
2019-12-11 19:59:12 +08:00
debuggerdoubleenumexportextendsfinalfloatgoto
2018-10-02 22:10:26 +08:00
2019-12-11 19:59:12 +08:00
implementsimportintinterfacelongnativepackage
2018-10-02 22:10:26 +08:00
2019-12-11 19:59:12 +08:00
privateprotectedpublicshortstaticsupersynchronizedthrows
2018-10-02 22:10:26 +08:00
2019-12-11 19:59:12 +08:00
transientvolatile
2018-10-02 22:10:26 +08:00
```
2019-12-11 19:59:12 +08:00
## 举例
2018-10-02 22:10:26 +08:00
2019-12-11 19:59:12 +08:00
**举例1**交换两个变量的值
2018-10-02 22:10:26 +08:00
2019-12-11 19:59:12 +08:00
代码实现
2018-10-02 22:10:26 +08:00
```javascript
2019-12-11 19:59:12 +08:00
var a1 = 100;
var a2 = 200;
2018-10-02 22:10:26 +08:00
2019-12-11 19:59:12 +08:00
var temp;
2018-10-02 22:10:26 +08:00
2019-12-11 19:59:12 +08:00
temp = a1;
a1 = a2;
a2 = temp;
2018-10-02 22:10:26 +08:00
```
## 我的公众号
2019-12-11 18:16:28 +08:00
想学习**代码之外的技能**不妨关注我的微信公众号**千古壹号**id`qianguyihao`
2018-10-02 22:10:26 +08:00
扫一扫你将发现另一个全新的世界而这将是一场美丽的意外
2019-12-11 18:16:28 +08:00
![](http://img.smyhvae.com/20200101.png)
2018-10-02 22:10:26 +08:00