博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
js基础知识之-----作用域以及变量提升
阅读量:6123 次
发布时间:2019-06-21

本文共 828 字,大约阅读时间需要 2 分钟。

东西不用会生锈,感情不维会生怨。无论何种感情,不维护都会疏远。

一、作用域:

js中的作用域分为:全局作用域和局部作用域
当变量定义在一个函数中时,变量就在局部作用域中,而定义在函数之外的变量则从属于全局作用域。每个函数在调用的时候会创建一个新的作用域。
⑴全局作用域:
当你在文档中(document)编写 JavaScript 时,你就已经在全局作用域中了。JavaScript 文档中(document)只有一个全局作用域。定义在函数之外的变量会被保存在全局作用域中。
⑵局部作用域:
定义在函数中的变量就在局部作用域中。并且函数在每次调用时都有一个不同的作用域。这意味着同名变量可以用在不同的函数中。因为这些变量绑定在不同的函数中,拥有不同作用域,彼此之间不能访问。
二、⑴变量提升:
变量提升即将变量声明提升到它所在作用域的最开始的部分。
以下是一个简单的例子:

console.log(a); // undefinedvar a = 10; console.log(a); // 10 // 以上 变量a在定义之初就会被提升到所在作用域的最开始部分,所以第一次打印的是undefined,第二次赋值后打印的是10复制代码

 ⑵函数提升:
js中创建函数有两种方式:函数声明式和函数字面量式。只有函数声明才存在函数提升!

console.log(fun1); //function fun1(){}console.log(fun2); //undefinedfunction fun1(){}var fun2 = function(){}出现上面的情况,是因为函数声明的时候提升了,提到了最开始部分,所以fun1才会被打印,而fun2是函数赋值的变量,所以是属于变量提升,为undefined复制代码

注意:“函数会首先被提升,然后才是变量”。

转载于:https://juejin.im/post/5c909d0b5188252db4530b22

你可能感兴趣的文章
加解密算法、消息摘要、消息认证技术、数字签名与公钥证书
查看>>
while()
查看>>
常用限制input的方法
查看>>
Ext Js简单事件处理和对象作用域
查看>>
IIS7下使用urlrewriter.dll配置
查看>>
12.通过微信小程序端访问企查查(采集工商信息)
查看>>
WinXp 开机登录密码
查看>>
POJ 1001 Exponentiation
查看>>
HDU 4377 Sub Sequence[串构造]
查看>>
云时代架构阅读笔记之四
查看>>
WEB请求处理一:浏览器请求发起处理
查看>>
Lua学习笔记(8): 元表
查看>>
PHP经典算法题
查看>>
LeetCode 404 Sum of Left Leaves
查看>>
醋泡大蒜有什么功效
查看>>
hdu 5115(2014北京—dp)
查看>>
数据结构中常见的树(BST二叉搜索树、AVL平衡二叉树、RBT红黑树、B-树、B+树、B*树)...
查看>>
PHP读取日志里数据方法理解
查看>>
第五十七篇、AVAssetReader和AVAssetWrite 对视频进行编码
查看>>
Vivado增量式编译
查看>>