美文网首页
[2020-07-17]js变量提升

[2020-07-17]js变量提升

作者: may505 | 来源:发表于2020-07-17 16:09 被阅读0次
  • js函数的提升
console.log(a)
var a = 3
function a(){}
console.log(a)

输出结果

image.png
解析:我们在定义function a(){}后,会把function a(){}提升到最前面,相当于
function a(){}
console.log(a)
var a = 3
console.log(a)

所以最终输出的结果如上

  • js原型及全局变量
function Foo(){
    getName = function(){
        console.log(1)
    }
    return this
}
Foo.getName = function(){
    console.log(2)
}

Foo.prototype.getName = function() {
    console.log(0)
}

var getName = function() {
    console.log(3)
}

function getName() {
    console.log(5)
}
Foo.getName() // 2
getName() // 3
Foo().getName() // 1
getName() // 1
new Foo.getName() // 2
new Foo().getName() // 0

解析:

  1. Foo.getName()执行的是Foo.getName函数。
  2. getName()其中var getName = function()会覆盖掉function getName()
  3. Foo().getName(),其中执行Foo()的时候执行了getName = function()相当于又把getName函数给重新赋值定义了,而Foo()返回了this,该this指向window
  4. getName(),由于在步骤3的时候重新定义了getName函数,所以输出也发生了变化
  5. new Foo.getName()相当于执行了步骤1的过程。
  6. new Foo().getName()执行是Foo原型上的getName函数

相关文章

  • [2020-07-17]js变量提升

    js函数的提升 输出结果 解析:我们在定义 后,会把 提升到最前面,相当于 所以最终输出的结果如上 js原型及全局...

  • JS中的提升

    JS中包含两种提升,变量提升和函数提升。 变量提升 变量提升只能是var或者function声明的变量或者函数,l...

  • 浏览器学习笔记-JS执行

    变量提升 变量提升原理浏览器对js是先编译后执行,在编译过程中,js中的变量声明会被提升到代码段落前面。函数声明和...

  • JavaScript 大纲

    js 语法基础 JavaScript 介绍 js 输出 注释 变量,变量声明提升,全局变量,常量 7 大数据类型 ...

  • Javascript 变量执行过程 和 数组 & 对象的区别

    变量提升 JS执行过程1. 先提升(先提升函数,再提升变量,如果名字一样,变量提升会覆盖函数提升)2. 再执行,如...

  • 变量提升和函数提升

    JS不像C语言,C语言是先声明后使用,否则会报错。但JS中,有变量提升现象,可以先使用后声明。 JS存在变量提升,...

  • 前端经典面试题合集(一)

    1.谈谈变量提升 考察点:js基础知识,js执行机制,变量的提升答:执行js代码时,会生成执行环境,在函数中的代码...

  • 变量声明提升

    变量声明提升是JS中一个基础的问题,同时也是对JS词法作用域认识的一个提升。在JS面试题中,关于变量声明提升的问题...

  • JS变量提升

    废话不多说,直接看以下例子,代码地址: 函数声明和函数表达式 很明显,这个大家都知道这个答案,就是很常见的作用域提...

  • js变量提升

    JavaScript的函数在查找变量时从自身函数定义开始,从“内”向“外”查找。如果内部函数定义了与外部函数重名的...

网友评论

      本文标题:[2020-07-17]js变量提升

      本文链接:https://www.haomeiwen.com/subject/dpvghktx.html