首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

JS的 if 中的函数声明提升

从ES6开始 在严格模式下,块里的函数作用域为这个块。ES6之前不建议块级函数在严格模式下使用....在ES6非严格模式下, 块中函数声明会出现提升, 所以最好使用函数表达式来定义函数 ---- 走走流程看看到底发生了啥 我们可以先把, function a () {}注释掉, 可以看到报错了, Uncaught...ReferenceError: a is not defined, 所以if里的函数声明确实存在变量提升 ?...然后, 我们可以打点调试一下 在if 中的a=1语句之前, 我们可以看到函数声明已经提升了, 此时if作用域里a为函数 ? 而全局的a还是undefined ?...随后运行a=5, 则只是在块级作用域里的赋值, 不会对全局作用域的a值进行修改 ---- 当然, 如果使用函数表达式来声明函数的话, 可以避免 var a if (true) { console.log

3.7K20
您找到你想要的搜索结果了吗?
是的
没有找到

JavaScript-变量函数声明提升

二、变量声明提升 2.1 hoisting (1)由于变量声明(以及其他声明)总是在任意代码执行之前处理,所以在代码中的任意位置声明变量总是等效于在代码开头声明。...(4)重要的是,提升将影响变量声明,而不会影响其值的初始化。当到达赋值语句时,该值将确实被分配。 ?...四、函数表达式 区分函数声明函数表达式的规则:函数声明总是以function关键词开始,如果不是,那它就是一个函数表达式。...(1)函数表达式不是以function关键词开始(一般出现在代码的中间部分) ? 五、函数声明提升 ? 六、函数声明优先级较高 (1)函数声明比变量声明的优先级高。 ?...(2)如果两者同名,并且同时存在,后被提升函数声明会覆盖先被提升的变量声明。 ? 参考文章 详解Javascript 函数声明函数表达式的区别

1.1K20

js变量提升函数提升

两个最简单的例子理解变量声明提升函数声明提升 一、变量提升 变量提升即将变量声明提升到它所在作用域的最开始的部分 例1: function fn () { var a ="hello...但是我需要说明的是,变量提升 只是提升变量的声明,并不会把赋值也提升上来 二、函数提升 js中创建函数有两种方式:一种是函数表达式,另外一种是函数声明方式。只有函数声明才存在函数提升!...、通常JS引擎会在正式执行之前先进行一次预编译,在这个过程中,首先将变量声明函数声明提升至当前作用域的顶端,然后进行接下来的处理 2、如果当前作用域中存在此变量声明,无论它在什么地方声明,引用此变量时就会在当前作用域中查找...,不会去外层作用域了 3、let和const关键字没有变量提升 2、函数提升 1、如果在同一个作用域中存在多个同名函数声明,后面出现的将会覆盖前面的函数声明 2、函数声明的优先级最高,会被提升至当前作用域最顶端...,所以第一次调用时实际执行了下面定义的函数声明,然后第二次调用时,由于前面的函数表达式与之前的函数声明同名,故将其覆盖,以后的调用也将会打印同样的结果 3、函数的优先权是最高的,它永远被提升至作用域最顶部

1.3K41

JS 声明

用 var 声明的变量的作用域是它当前的执行上下文,它可以是嵌套的函数,也可以是声明在任何函数外的变量。如果你重新声明一个 JavaScript 变量,它将不会丢失其值。...变量提升 由于变量声明(以及其他声明)总是在任意代码执行之前处理的,所以在代码中的任意位置声明变量总是等效于在代码开头声明。这意味着变量可以在声明之前使用,这个行为叫做“hoisting”。...“hoisting”就像是把所有的变量声明移动到函数或者全局代码的开头位置。...重要的是,提升将影响变量声明,而不会影响其值的初始化。...SyntaxError错误, 因为**var**会将变量提升至块的顶部, 这会导致隐式地重复声明变量. let x = 1; { var x = 2; // SyntaxError for re-declaration

2.5K10

《前端实战》之变量提升函数声明提升及变量作用域详解

正文 1.变量是如何被覆盖的 在一般情况下,js代码都是自上而下执行的,对于同一个变量,我们可以通过如下方式来修改: var a = 1; a = 2; console.log(a) // 2 a...我们在用var或者函数声明的方式定义一个变量时,这个变量的定义会提升到方法体的最顶端,即如下所示: var a = undefined; var b = undefined; console.log(a...) // .. console.log(b) 因此我们得出一条结论: 函数声明和变量声明总是会被解释器悄悄地被"提升"到方法体的最顶部。...这个问题也是我之前面试一些求职者的过程中错误高发区,这里隐藏着一个概念:函数声明提升的优先级高于变量声明提升。...浏览器底层的实现过程是这样的:当js解析器在遇到函数声明时,会优先将其提升到定义体顶部,其次再是var声明的变量,这样就导致函数a被变量a给覆盖的情况,所以最终将打印1。

69310

函数声明

statements 构成函数体的语句。 描述 通过函数声明构造的函数是Function对象,所以拥有一切Function对象所有的属性,方法和行为。...函数默认返回undefined,如果想返回其他值,函数必须使用return语句来返回你想返回的值。 通过条件语句判断创造的函数 函数可以通过条件语句来声明,也就是说函数可以内嵌在if语句中。...除了Mozilla之外的所有浏览器都将用条件语句来声明函数当做没有条件语句的声明并且无论if判断true还是false都将创造一个函数。...所以不要通过if语句的条件判断来选择性的声明一个函数,你可以在if语句中选择使用函数表达式方法来创建函数。...函数声明提前Function declaration hoisting 在JS函数声明将会提前于函数定义。

70920

js变量提升函数提升的详细过程

js变量提升函数提升的详细过程 先来看两个栗子,下面的两段代码分别输出什么?...这就涉及到js中的变量提升函数提升的具体过程了。 1、变量的提升 js是怎么创建变量的呢?...原本js定义变量的地方,在js运行到这里的时候,才会进行赋值操作,而没有运行到的变量,不会进行赋值操作。 所以变量的提升提升的其实是变量的声明,而不是变量的赋值。...2、函数提升 函数提升和变量的提升类似,都是提升到作用域的最开始的位置,只不过变量的提升是分两步的,第一步是变量声明提升,第二步是变量的赋值。...,但是变量赋值的部分是在js原型到变量定义的位置才给变量赋值的,而函数提升是相当于直接剪切到最前面的。

1.5K30

js中构造函数和普通函数的区别_函数声明函数定义

1、构造函数也是一个普通函数,创建方式和普通函数一样,但构造函数习惯上首字母大写 2、构造函数和普通函数的区别在于:调用方式不一样。...普通函数的调用方式:直接调用 person(); b.构造函数的调用方式:需要使用new关键字来调用 new Person(); 4、构造函数函数名与类名相同:Person( ) 这个构造函数...A、立刻在堆内存中创建一个新的对象 B、将新建的对象设置为函数中的this C、逐个执行函数中的代码 D、将新建的对象作为返回值 6、普通函数例子...:因为没有返回值,所以为undefined 7、构造函数例子:构造函数会马上创建一个新对象,并将该新对象作为返回值返回 8、用instanceof 可以检查一个对象是否是一个类的实例...,是则返回true; 所有对象都是Object对象的后代,所以任何对象和Object做instanceof都会返回true 版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。

3.1K10

JS面试、技巧总结点一-变量提升函数提升

什么是变量/函数提升 包括变量和函数在内的所有声明都会在任何代码被执行前首先被处理,这种现象称为提升。...JS 解释器会找出需要提升的变量和函数,并且给他们提前在内存中开辟好空间,函数的话会将整个函数存入内存中,变量只声明并且赋值为 undefined, 第一个定义声明是在编译阶段进行的。...这个过程就叫作提升。 JavaScript只会将变量声明提升,但是不会把初始化提升。...var a = 200, 所以 var a会被提升到fn的作用域顶端,第一输出则为undefined 下面这段代码,由于es6之前,js是没有块级作用域的,所以 if 中声明的a变量会被当成全局变量处理...,所以 fx 里面访问的变量a,其实都是访问的全局变量a,a = 20 又相当于给全局变量a重新赋值20 函数声明提升 通过function声明函数,在之前就可以直接调用 fx() // fx is

75420

JS函数声明函数表达式的异同

-- function body --> } 函数声明会提前 函数声明是在预执行期执行的,就是说函数声明是在浏览器准备执行代码的时候执行的。...因为函数声明在预执行期被执行,所以到了执行期,函数声明就不再执行(人家都执行过了自然就不再执行了)。...; })() 事实上,js的解析器对函数声明函数表达式并不是一视同仁地对待的。...对于函数声明js解析器会优先读取,确保在所有代码执行之前声明已经被解析,而函数表达式,如同定义其它基本类型的变量一样,只在执行到某一句时也会对其进行解析,所以在实际中,它们还是会有差异的,具体表现在,...当使用函数声明的形式来定义函数时,可将调用语句写在函数声明之前,而后者,这样做的话会报错。

1.1K50

JavaScript(js函数声明函数表达式的区别

在JavaScript中,函数是经常用到的,在实际开发的时候,我想很多人都没有太在意函数声明函数表达式的区别,但是呢,这种细节的东西对于学好js是非常重要的。...函数声明函数表达式用代码写出来是这样的: //函数声明 function say(){ console.log("函数声明") } //函数表达式 var say1 = function(){...undefined,这是不是很像我们的函数表达式了,其实,如果说我们在函数表达式之前也打印一下这个say1(),结果也是undefined,原因就是带有var 的变量,当然这里说的是全局变量,它在预解析的时候会有一个变量提升...,变量提升是什么意思呢,看上面这段代码,其实就相当于下面这段代码 var a; console.log(a); a=1; 现在知道了吧,a这个变量是存在的,并且初始化成了一个undefined,所以说我们的函数表达式也是一样的...,它也有变量提升,在将函数赋值给你定义的变量之前,调用就会报它不是函数的错,而打印出来就是undefined,是不是很好理解呢,学到了吗?

79030
领券