首页
学习
活动
专区
工具
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 声明

用 var 声明的变量的作用域是它当前的执行上下文,它可以是嵌套的函数,也可以是声明在任何函数外的变量。如果你重新声明一个 JavaScript 变量,它将不会丢失其值。...“hoisting”就像是把所有的变量声明移动到函数或者全局代码的开头位置。...let let不会在全局声明时(在最顶部的范围)创建window 对象的属性。 let允许你声明一个作用域被限制在 块级中的变量、语句或者表达式。...比如: 位于函数或代码顶部的var声明会给全局对象新增属性, 而let不会。...常量是块级作用域,很像使用 let 语句定义的变量。常量的值不能通过重新赋值来改变,并且不能重新声明。 const****声明创建一个值的只读引用。

2.5K10
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    函数声明

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

    73120

    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

    第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

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

    -- 函数表达式 --> var sayTruth=function(){ alert('myvin is handsome.'); } ECMAScript规范中表示,函数声明语句可以出现在全局代码中...,或者内嵌在其他函数中,但是不能出现在循环、条件判、或者try/finally以及with语句中。...; })() 事实上,js的解析器对函数声明函数表达式并不是一视同仁地对待的。...对于函数声明js解析器会优先读取,确保在所有代码执行之前声明已经被解析,而函数表达式,如同定义其它基本类型的变量一样,只在执行到某一句时也会对其进行解析,所以在实际中,它们还是会有差异的,具体表现在,...当使用函数声明的形式来定义函数时,可将调用语句写在函数声明之前,而后者,这样做的话会报错。

    1.2K50

    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

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

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

    1.4K20

    函数(三)(函数声明

    函数声明 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

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

    1.函数表达式vs函数声明 函数声明函数表达式是使用 function 关键字创建函数的2种方法。...其原因是sumA是使用函数声明创建的,该函数声明在当前作用域中创建一个函数变量(具有与函数名称相同的名称)。...const sum = (function sumB(a, b) { return a + b; }); sum(1, 2); // => 3 如果语句以`function`关键字开头,则为函数声明...(4, 5); // => 9 当一个语句包含function关键字,后跟函数名称,一对带参数的括号(param1, param2, paramN)以及包围在一对花括号{}中的函数主体时,就会发生函数声明...由于提升,函数变量在函数声明之前可用。 2.1 函数声明的注意事项 函数声明语法的作用是创建独立函数函数声明应在全局作用域内,或直接在其他函数的作用域内: // Good!

    74430

    【JavaScript】函数 ① ( 函数引入 | 函数声明 | 函数调用 )

    , 使代码更加清晰和易于维护 ; 函数 的 目的 就是 重复使用代码 ; 使用函数 就是 声明函数 和 调用函数 ; 2、函数声明 在 JavaScript 中 , 使用 function 关键字 声明函数...; 函数定义语法格式 : // 声明 JavaScript 函数 function functionName(parameter1, parameter2, ...) { // 函数体:执行的代码块...是 传递给函数的 形式参数列表 , 这些 形式参数 在 函数体代码中 可与作为局部变量使用 ; 代码示例 : // 声明函数 function hello(name) {...字符串 ; 3、函数调用 函数声明后 , 本身不会自动执行 函数体中的代码 , 只有 调用函数后 , 才会执行 函数体代码 ; 函数调用 语法格式 : functionName(argument1, argument2...是传递给函数的 实参列表 , 该 实参列表 与 函数定义的 形参列表一一对应 , 这些实际参数值值将替换函数定义中的形式参数 , 并在函数执行时 作为 函数体的 局部变量 使用 ; 4、代码示例 - 函数声明调用

    14610

    JavaScript: 函数式编程 - 声明函数

    - 代码组合的优势 3-了解 JavaScript 函数式编程 - 声明函数 4-了解 JavaScript 函数式编程 - 类型签名 声明声明式代码 什么是声明式,我们将不再指示计算机如何工作...声明式 var makes = cars.map(function(car){ return car.make; }); 复制代码 命令式的循环要求你必须先实例化一个数组,而且执行完这个实例化语句之后...上面这句话有点难以理解,我们来看一个栗子 let meetup = {name:'JS',isActive:true,members:49}; const scheduleMeetup = (date,...所以我们需要纯函数声明函数来隔离这种无用的错误。 为什么使用声明式方式的函数函数? 在纯函数中,我们总是能保证我们的输出。 低复杂度,我们只需要考虑的是他是做什么的,而不是在乎过程怎么完成的。...易于测试,我们不用依赖于函数的状态,我们只关心结果的验证。 函数式编程更加易于理解。 总结 声明式和命令式的区别和含义,这里我们可以结合上一篇文章 组合代码 相关知识。

    1.3K30

    python 函数声明和调用

    一.函数的定义 在Python中,定义一个函数要使用def语句,依次写出函数名、括号、括号中的参数和冒号:,然后,在缩进块中编写函数体,函数的返回值用return语句返回;如果没有return语句,默认返回...注意:函数在调用之前必须先声明。python中的内置函数如:print/type函数等等已经在python编译器内部声明并且定义好了,我们只管调用即可,不需要关心具体内部如何实现。...函数声明的时候定义的参数叫做形参;外部调用函数传递的参数叫做实参;函数的参数有两者类型: 1.常规参数 常规而言,函数默认有几个形参,在外部调用时就需要传递多少个实参,示例代码如下: def cusom_print1...五.重点总结 1.函数声明必须在调用之前,否则会报错. 2.注意缺省参数的参数写法 3.函数没有使用return,默认返回None 猜你喜欢: 1.pycharm配置开发模板/设置字体大小 2.python...列表推导式 3.python字典推导式 4.python 函数不定长参数 *argc,**kargcs 转载请注明:猿说Python » python函数声明和调用

    3.4K01

    扫码

    添加站长 进交流群

    领取专属 10元无门槛券

    手把手带您无忧上云

    扫码加入开发者社群

    相关资讯

    热门标签

    活动推荐

      运营活动

      活动名称
      广告关闭
      领券