• javascript基础知识-命名提前,作用域


    javascript的代码存在命名提前的现象,在这里结合javascript的特殊作用域来解释。

    一般很多后台语言,比如C#都是块级作用域,也就是花括号范围内定义的变量,作用域被限制在花括号以内。

    而javascript则是函数级作用域,也就是说在函数体内定义的变量,拥有在函数内的作用域。

    比如下面的例子:

    function test(o){
        var i = 0;                                    //i在整个函数体内均有定义
        if(typeof o == "object"){
            var j = 0;                                //j在整个函数体内是有定义的,不仅仅是这个代码段内
            for(var k = 0;k<10;k++){
                console.log(k);                   //k在函数体内是有定义的,不仅仅实在循环内
            }
            console.log(k);                       //输出0~9
        }
        console.log(j);                            //j已经定义了,但可能没有初始化
    }    

    这里存在一个问题,倒数第二行的console(j)中的j为什么可能没有初始化呢?

    因为根据传入的参数o,j有可能被初始化,有可能不被初始化,比如test({}),就会被初始化,而test(99)则不会进入if语句块。

    这里要注意,函数的初始化还是留在原来的位置的,知识命名提前了。

    另外今天还学到一个知识点

    javascript里声明的所有变量(但不涉及赋值)都被"提前"值函数体顶部,重点是赋值不会提前!

    var scope = "global";
    function f(){
      console.log(scope);  //输出undefined
      var scope = "local";  
      console.log(scope);  输出"local"
    }
  • 相关阅读:
    package.json和bower的参数解释
    移动端<meta>属性配置讲解(整理)
    PHP Ajax 跨域问题最佳解决方案
    svn客户端的使用
    TotoiseSVN的基本使用方法
    网页设计入门——UCASiGEM前端组寒假培训笔记
    manacher算法笔记
    【luoguP1168】中位数
    【CF848B】 Rooter's Song
    【luoguP1382】楼房
  • 原文地址:https://www.cnblogs.com/zjtTT/p/4993252.html
Copyright © 2020-2023  润新知