js变量提升

作者: Aniugel | 来源:发表于2019-07-29 15:16 被阅读0次

1、如果一个声明的变量在函数体内,那他们的作用域就是函数的内部,如果在去全局作用域下声明,那他的作用域就是全局的。通过var 声明发的变量是无法用delete删除的。

/ num1为全局变量,num2为window的一个属性
var num1 = 1;
num2 = 2;
// delete num1;  无法删除
// delete num2;  删除
function model(){
var num1 = 1; // 本地变量
num2 = 2;     // window的属性
    // 匿名函数
    (function(){
        var num = 1; // 本地变量
        num1 = 2; // 继承作用域(闭包)
        num3 = 3; // window的属性
    }())
}
var a = 9;
    function demo() {
        console.log(a)
    }
    console.log('a' in window)//true
    console.log(window['a'])//9
    console.log(window.a)//9
    window.demo()//9

2、函数内部的声明的变量会被提升到函数的头部,函数在执行解析的时候,先进行变量声明处理,然后在运行函数内部的代码

if(!('a' in  window)){
  var a=1;//在解析时先声明var a  在window中  为true 
image.png
image.png

3、变量和赋值语句一起书写,在js引擎解析时,会将其拆成声明和赋值语句2部分,声明置顶,赋值保留在原来的位置

var a=1;//拆解成如下
var a;
console.log(a)//undefined
a=1;

4、变量重复声明不会报错,后面的会覆盖前面的

image.png

相关文章

  • 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的函数在查找变量时从自身函数定义开始,从“内”向“外”查找。如果内部函数定义了与外部函数重名的...

  • js变量提升

    对于大多数js开发者来说,变量提升可以说是一个非常常见的问题,但是可能很多人对其不是特别的了解。所以在此,我想来讲...

网友评论

    本文标题:js变量提升

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