From a89d6be4c743750bdb22fe4b2d8352d68199ebef Mon Sep 17 00:00:00 2001 From: qianguyihao Date: Wed, 3 Jun 2020 23:02:10 +0800 Subject: [PATCH] =?UTF-8?q?add:=20=E6=9A=82=E6=97=B6=E6=80=A7=E6=AD=BB?= =?UTF-8?q?=E5=8C=BA=20DTC?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- 04-JavaScript基础/18-作用域和变量提升.md | 6 ++ 05-JavaScript进阶/01-var、let、const的区别.md | 64 +++++++++++++++++++ .../MySQL数据库/03-MySQL的基本操作.md | 17 +++-- 16-推荐链接/04-前端文章推荐.md | 4 ++ 4 files changed, 86 insertions(+), 5 deletions(-) create mode 100644 05-JavaScript进阶/01-var、let、const的区别.md diff --git a/04-JavaScript基础/18-作用域和变量提升.md b/04-JavaScript基础/18-作用域和变量提升.md index 66d2da8..57e6d43 100644 --- a/04-JavaScript基础/18-作用域和变量提升.md +++ b/04-JavaScript基础/18-作用域和变量提升.md @@ -125,6 +125,12 @@ function foo() { 打印结果:undefined。注意,打印结果并没有报错,而是 undefined。这个例子,再次说明了:变量 i 在函数执行前,就被提前声明了,只是尚未被赋值。 +例4中, `if(false)`里面的代码虽然不会被执行,但是整个代码有**解析**的环节,解析的时候就已经把 变量 i 给提前声明了。 + + +**总结**: + +既然JS中存在变量提升的现象,那么,在实战开发中,为了避免出错,建议先声明一个变量,然后再使用这个变量。 ### 函数的声明提前 diff --git a/05-JavaScript进阶/01-var、let、const的区别.md b/05-JavaScript进阶/01-var、let、const的区别.md new file mode 100644 index 0000000..697b6f1 --- /dev/null +++ b/05-JavaScript进阶/01-var、let、const的区别.md @@ -0,0 +1,64 @@ + + + +## var、let、const的区别 + +### var声明的变量存在变量提升,let和const声明的变量不存在变量提升 + +var 声明的变量: + +```js +console.log(a); // 打印结果:undefined ==> a已经声明但没有赋值 +var a = '我是a'; +``` + +let 声明的变量: + +```js +console.log(b); // 打印结果报错:Uncaught ReferenceError: Cannot access 'b' before initialization ==> 找不到b这个变量 +let b = '我是b'; +``` + +const 声明的变量: + +```js +console.log(c); // 打印结果报错:Uncaught ReferenceError: Cannot access 'c' before initialization ==> 找不到c这个变量 +const c = '我是c'; +``` + + +### 暂时性死区 DTC + +举例1:(表现正常) + +```js +const name = 'qianguyihao'; + +function foo() { + console.log(name); +} + +foo(); // 执行函数后,打印结果:smyhvae +``` + +上方例子中, 变量 name 被声明在函数外部,此时函数内部可以直接使用。 + +**举例2**:(报错) + +```js +const name = 'qianguyihao'; + +function foo() { + console.log(name); + const name = 'hello'; +} + +foo(); // 执行函数后,控制台报错:Uncaught ReferenceError: Cannot access 'name' before initialization +``` + +代码解释:如果在当前块作用域中使用了变量 name,并且当前块作用域中通过 let/const 声明了这个变量,那么,**声明语句必须放在使用之前,也就是所谓的 DTC(暂时性死区)**。DTC其实是一种保护机制,可以让我们的代码写得更佳完善。 + + +## 参考链接 + +- [JS中var、let、const区别](https://juejin.im/post/5e49249be51d4526e651b654) \ No newline at end of file diff --git a/10-Node.js和数据库/MySQL数据库/03-MySQL的基本操作.md b/10-Node.js和数据库/MySQL数据库/03-MySQL的基本操作.md index ebd93b3..701c317 100644 --- a/10-Node.js和数据库/MySQL数据库/03-MySQL的基本操作.md +++ b/10-Node.js和数据库/MySQL数据库/03-MySQL的基本操作.md @@ -405,7 +405,18 @@ alter table 表名 add 新字段名 字段类型 字段位置; ``` -**举例**: +**举例1**: + +在 `name`字段的后面,新增一个 `sex` 字段: + +```sql +alter table t_qiangu1 add sex varchar(255) default null comment '性别' after name; +``` + +注意,上方举例中,如果是新建 varchar 类型的字段,一定要指定 varchar 的长度(比如255),否则报错。 + +**举例2**: + 新增一个 `id` 字段,放到最前面: @@ -413,11 +424,7 @@ alter table 表名 add 新字段名 字段类型 字段位置; alter table t_qiangu1 add id int first; ``` -在 `name`字段的后面,新增一个 `sex` 字段: -```sql -alter table t_qiangu1 add sex varchar(255) after name; -``` ### 3、change:修改现有字段的字段名 diff --git a/16-推荐链接/04-前端文章推荐.md b/16-推荐链接/04-前端文章推荐.md index 396985c..39c0988 100644 --- a/16-推荐链接/04-前端文章推荐.md +++ b/16-推荐链接/04-前端文章推荐.md @@ -7,6 +7,10 @@ React 中的 setState 是异步操作。 +### 2020-03-27 + +- [「颜值即正义」那些管UI小姐姐要来的网站](https://juejin.im/post/5e7cdee26fb9a03c6e640cc7) + ### 2020-04-09 - [使用 ImgBot 自动为 Github 项目优化图片](https://www.cnblogs.com/lfri/p/12257277.html)