function 声明和变量声明有什么不同? - V2EX
V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
推荐关注
Meteor
JSLint - a Javascript code quality tool
jsFiddle
D3.js
WebStorm
推荐书目
Javascript 权威指南第 5 版
Closure: The Definitive Guide
lbfeng

function 声明和变量声明有什么不同?

  •  
  •   lbfeng 2019 年 6 月 21 日 4008 次点击
    这是一个创建于 2499 天前的主题,其中的信息可能已经有所发展或是发生改变。
    var foo = 2; console.log(foo); // 2 function foo() { } console.log(foo); // 2 
    var foo = 2; console.log(foo); // 2 foo = function () { } console.log(foo); // function 
    function foo() { } console.log(foo); // function var foo = 2; console.log(foo); // 2 

    var foo可以覆盖function foo, 反之就不行。js 编译对这种操作是怎么解决的?感觉哪块知识有欠缺。

    第 1 条附言    2019 年 6 月 21 日
    懂了。。。。var foo 和 function foo 还是不一样的。function foo 的 hoist 某种程度比 var 优先。
    var foo = 2;
    console.log(foo); // 2

    function foo() {

    }
    console.log(foo); // 2

    其实变成了
    function foo() {

    }
    var foo
    foo = 2;
    console.log(foo); // 2
    console.log(foo); // 2
    第 2 条附言    2019 年 6 月 21 日
    10 条回复    2019-06-24 01:56:29 +08:00
    Orenoid
        1
    Orenoid  
       2019 年 6 月 21 日 via Android
    我记得 function 声明好像会提升到前面先解释,不是前端,说错勿喷。。
    akiakiseofficial
        2
    akiakiseofficial  
       2019 年 6 月 21 日 via iPhone
    标识符优先级吧,楼下解释,我也不是前端
    Yvette
        3
    Yvette  
       2019 年 6 月 21 日
    楼上好像说反了,是 Variable Hoisting,变量的声明会提升到前面
    faywong8888
        4
    faywong8888  
       2019 年 6 月 21 日 via iPhone
    一个是词法环境下的函数名,不可变(程序员代码运行时不可改变它);一个是普通的变量,可以随便玩
    rabbbit
        5
    rabbbit  
       2019 年 6 月 21 日   2
    进入函数时分两步:
    1 扫描函数内的所有函数和变量,将其绑定到作用域
    2 执行函数代码

    可以把作用域理解成一个对象, 要的时候就去这个对象里找.
    对于步骤 1 也是有顺序的
    先扫描函数,然后在扫描变量


    所以实际运行代码是
    1
    ```
    function foo() {

    }

    foo = 2; // 这个其实 不会被提升, 因为有同名函数了
    console.log(foo); // 2
    console.log(foo); // 2
    ```
    2
    ```
    var foo;

    foo = 2;
    console.log(foo); // 2

    foo = function () {

    }
    console.log(foo); // function
    ```
    3
    ```
    function foo() {

    }
    console.log(foo); // function

    foo = 2;
    console.log(foo); // 2
    ```
    liuy1994g
        6
    liuy1994g  
       2019 年 6 月 21 日 via Android
    就是变量声明提升,function 和 var 可以看作一样的东西
    wolfie
        7
    wolfie  
       2019 年 6 月 21 日
    非前端,第一次碰到时候真的是蒙逼。

    [var 关于变量提升]( https://www.jianshu.com/p/184cb2075d16)
    lbfeng
        8
    lbfeng  
    OP
       2019 年 6 月 21 日
    @rabbbit 正解。var foo 被忽略了。
    Takamine
        9
    Takamine  
       2019 年 6 月 22 日
    所以我用 let。:doge:
    dartabe
        10
    dartabe  
       2019 年 6 月 24 日
    函数声明和函数表达式的区别 函数声明是第一公民 提到最前面 函数表达式只是把变量声明提前 赋值还是在当前位置
    关于     帮助文档     自助推广系统     博客     API     FAQ     Solana     2879 人在线   最高记录 6679       Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 66ms UTC 05:26 PVG 13:26 LAX 22:26 JFK 01:26
    Do have faith in what you're doing.
    ubao msn snddm index pchome yahoo rakuten mypaper meadowduck bidyahoo youbao zxmzxm asda bnvcg cvbfg dfscv mmhjk xxddc yybgb zznbn ccubao uaitu acv GXCV ET GDG YH FG BCVB FJFH CBRE CBC GDG ET54 WRWR RWER WREW WRWER RWER SDG EW SF DSFSF fbbs ubao fhd dfg ewr dg df ewwr ewwr et ruyut utut dfg fgd gdfgt etg dfgt dfgd ert4 gd fgg wr 235 wer3 we vsdf sdf gdf ert xcv sdf rwer hfd dfg cvb rwf afb dfh jgh bmn lgh rty gfds cxv xcv xcs vdas fdf fgd cv sdf tert sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf shasha9178 shasha9178 shasha9178 shasha9178 shasha9178 liflif2 liflif2 liflif2 liflif2 liflif2 liblib3 liblib3 liblib3 liblib3 liblib3 zhazha444 zhazha444 zhazha444 zhazha444 zhazha444 dende5 dende denden denden2 denden21 fenfen9 fenf619 fen619 fenfe9 fe619 sdf sdf sdf sdf sdf zhazh90 zhazh0 zhaa50 zha90 zh590 zho zhoz zhozh zhozho zhozho2 lislis lls95 lili95 lils5 liss9 sdf0ty987 sdft876 sdft9876 sdf09876 sd0t9876 sdf0ty98 sdf0976 sdf0ty986 sdf0ty96 sdf0t76 sdf0876 df0ty98 sf0t876 sd0ty76 sdy76 sdf76 sdf0t76 sdf0ty9 sdf0ty98 sdf0ty987 sdf0ty98 sdf6676 sdf876 sd876 sd876 sdf6 sdf6 sdf9876 sdf0t sdf06 sdf0ty9776 sdf0ty9776 sdf0ty76 sdf8876 sdf0t sd6 sdf06 s688876 sd688 sdf86