首页
学习
活动
专区
工具
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
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    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.2K10

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

    这里就涉及到了函数的传递,函数的传递是传引用,就是说函数存在内存的某个位置,nameAlert和anotherNameAlert是都是函数的一个引用,把函数名nameAlert赋值给anotherNameAlert...-- 函数表达式 --> var sayTruth=function(){ alert('myvin is handsome.'); } ECMAScript规范中表示,函数声明语句可以出现在全局代码...,或者内嵌在其他函数,但是不能出现在循环、条件判、或者try/finally以及with语句中。...; })() 事实上,js的解析器对函数声明函数表达式并不是一视同仁地对待的。...对于函数声明js解析器会优先读取,确保在所有代码执行之前声明已经被解析,而函数表达式,如同定义其它基本类型的变量一样,只在执行到某一句时也会对其进行解析,所以在实际,它们还是会有差异的,具体表现在,

    1.2K50

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

    Js函数声明是指下面的形式: function functionName(){ }         这样的方式来声明一个函数,而函数表达式则是类似表达式那样来声明一个函数,如: var functionName...= function(){ }         可能很多朋友在看到这两一种写法时会产生疑惑,这两种写法差不多,在应用貌似也都是可行的,那他们有什么差别呢?       ...事实上,js的解析器对函数声明函数表达式并不是一视同仁地对待的。...对于函数声明js解析器会优先读取,确保在所有代码执行之前声明已经被解析,而函数表达式,如同定义其它基本类型的变量一样,只在执行到某一句时也会对其进行解析,所以在实际,它们还是会有差异的,具体表现在,...当使用函数声明的形式来定义函数时,可将调用语句写在函数声明之前,而后者,这样做的话会报错。

    1.4K20

    JS 函数表达式和函数声明你混淆了吗?

    但是sumB是使用函数表达式创建的(将其包装在括号),该函数表达式不会在当前作用域内创建函数变量。 如果你想访问使用函数表达式创建的函数,那么将函数对象保存到一个变量: // Works!...2.函数声明 在前面的示例已经看到的,sumA是一个函数声明: // Function declaration function sumA(a, b) { return a + b; } sumA...(4, 5); // => 9 当一个语句包含function关键字,后跟函数名称,一对带参数的括号(param1, param2, paramN)以及包围在一对花括号{}函数主体时,就会发生函数声明...函数声明会创建一个函数变量:一个与函数名称同名的变量(例如,上一个示例的sumA)。 在当前作用域中(在函数声明之前和之后),甚至在函数作用域本身内,都可以访问该函数变量。...: 如果表达式函数没有名称,例如 function(){return 42},那是一个匿名函数表达式 如果函数具有名称,例如 上一个示例的sumB和回调,那么这是一个命名函数表达式 3.1 函数表达式的注意事项

    74430

    JS 声明

    用 var 声明的变量的作用域是它当前的执行上下文,它可以是嵌套的函数,也可以是声明在任何函数外的变量。如果你重新声明一个 JavaScript 变量,它将不会丢失其值。...变量提升 由于变量声明(以及其他声明)总是在任意代码执行之前处理的,所以在代码的任意位置声明变量总是等效于在代码开头声明。这意味着变量可以在声明之前使用,这个行为叫做“hoisting”。...let let不会在全局声明时(在最顶部的范围)创建window 对象的属性。 let允许你声明一个作用域被限制在 块级的变量、语句或者表达式。...作用域规则 let声明的变量只在其声明的块或子块可用,这一点,与var相似。二者之间最主要的区别在于var声明的变量的作用域是整个封闭函数。...该变量处在一个自块顶部到初始化处理的“暂存死区”。 所以说变量一定要先声明, 后使用.

    2.5K10

    函数声明

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

    73120

    第24天:js-函数变量声明提升

    一、函数声明 1、自定义函数 function fun1(){ alert("我是自定义函数"); } fun2();//函数不调用,自己不执行 2、直接量声明 var fun2=function()...{ alert("直接量声明"); } fun2(); 3、利用Function关键字声明 var fun3=new Function("var a=10;b=20;alert(a+b)"); fun3...(); 二、变量声明提升 如果在一个函数体内部声明了一个变量,不管这个变量函数外部有没有,先执行函数内部的变量,会将变量声明提升到函数开始部分,但是不会赋值。...在函数体内部声明变量,会把该声明提升到函数体的最顶端。但是只提升变量声明,不赋值。...函数实参个数要与形参个数相同,arguments.length可以获取函数实参的个数 1 <!

    1.8K10

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

    在JavaScript函数是经常用到的,在实际开发的时候,我想很多人都没有太在意函数声明函数表达式的区别,但是呢,这种细节的东西对于学好js是非常重要的。...函数声明函数表达式用代码写出来是这样的: //函数声明 function say(){ console.log("函数声明") } //函数表达式 var say1 = function(){...首先,在函数调用方面,看下面的代码 say(); //函数声明 function say(){ console.log("函数声明") } 这样的执行结果是什么呢?...答案是打印出“函数声明”,那你看下面的代码 say1(); //函数声明 function say(){ console.log("函数声明") } //函数表达式 var say1 = function...一起来看看,首先我们先说第一种,函数声明的调用,函数声明的调用这个其实不用讲你就知道,函数声明了嘛,哪里都可以调用的(function会有预解析,预解析之后函数就存在了,所以那里都能调用它了)。

    81230

    javascript函数声明函数表达式

    在javascript,我们经常要声明函数,或者使用函数表达式,今天我们就来说说这两者的区别。 解析器在执行代码的时候,对函数声明函数表达式并不是一致的。...解析器会优化读取函数声明,这是为了使其他代码在使用此函数之前可以使用,函数表达式则不然,必须到函数表达式执行到所在代码的区域才会被解释执行。...我们来看两个例子: 1.函数声明: console.log(action(10,20)) function action(num1,num2){ } 这段代码我们一直都知道,是可以通过的吧,这是因为解析器会优化读取函数...javascript引擎在第一次会声明函数并将他们放在源代码的顶部,所以即使函数声明在调用的后面,也能完成执行。 如果使用函数表达式,这样的调用就会报错。...在执行到函数所在语句之前,解析器根本找不到action这个函数,这就是函数声明函数表达式的区别。

    48610

    函数(三)(函数声明

    函数声明 C语言的函数调用要求是先定义后使用,就是要求被调用函数定义在主调函数之前。 如果在程序自定义函数时,需要将被调函数定义在主调函数后面,就需要的函数调用之前加上函数原型声明。...如果在函数调用之前既无函数定义,也无函数声明,编译时会出错。 函数原型声明的一般形式: 类型说明符 函数名(形式参数声明列表); 例:定义计算圆面积的函数,在主函数输入半径并计算面积。...参考代码: #include #define PI 3.14159 int main() { //函数原型声明 double circle(double...return ; } double circle(double radius) { return PI * radius * radius; } 函数声明函数名后面的圆括号可以只给出形参的类型...例如本例第5行的函数声明可以写成如下形式: double circle(double); 如果在源程序文件的开头部分,所有函数定义的前面进行函数声明,则该源程序文件中所有的函数都可以调用被声明函数

    64910

    Javascript函数声明函数表达式

    ."); }(); 试一下就知道这段代码的意思就是声明一个函数,然后立刻执行,因为Javascript的变量作用域是基于函数的,所以这样可以避免变量污染,但这里的位运算符『~』乍一看让人摸不到头脑...在阐述为什么之前,让我们先来明确Javascript的两个概念:函数声明函数表达式: 先来看看什么样的是函数声明: function() { alert("hello, world...alert("hello, world."); }; 现在回头看看文章开头的问题,为什么去掉位操作符『~』后运行会报错,这是因为从语法解析的角度看,Javascript不允许在函数声明的后面直接使用小括号...,而函数表达式则没有这个限制,通过在函数声明前面加上一个『~』操作符,就可以让语法解析器把后面看成是函数表达式,同样的,在函数声明前面加上『!...使用位操作符“~”的方法显得有点奇技淫巧,其实把函数声明用小括号套起来更易读: (function() { alert("hello, world."); })(); </script

    56520

    javascript函数声明函数表达式浅析

    在ECMAScript,有两个最常用的创建函数对象的方法,即使用函数表达式或者使用函数声明。...而如果 function foo(){} 被包含在一个函数体内,或者位于程序(的最上层),则将它作为一个函数声明来解析。显然,在省略标识符的情况下,“表达式” 也就只能是表达式了。...即使声明位于源代码的最后一行,它也会先于同一作用域中位于最前面的表达式被求值。还是看个例子更容易理解。在下面这个例子函数 fn 是在 alert 后面声明的。...由于存在上述限制,只要函数出现在块(像上面例子那样),实际上就应该将其看作一个语法错误,而不是什么函数声明或表达式。 那么我们应该在什么时候使用函数声明函数表达式呢?...函数声明只能出现在“程序代码”,意味着只能在其它函数或者全局空间;它们的定义不能不能赋值给一个变量或属性,或者作为一个参数传递出现在函数调用;下面的例子是函数声明的允许的用法,foo(),bar

    93290
    领券