10.js预解析

就是在代码执行之前,对代码进行通读解释

只解析两个内容:

(1)对var声明的变量

(2)声明式函数
(1)对var声明的变量进行提前声明,但不赋值

javascript 复制代码
var x
console.log(x)  //undefined

//分别输出几?
var num = 1;
function f1() {
    num = 2;
    var num;
    console.log(num) 
}
function f2() {
    console.log(num)  
}
f1();
f2();

/*
  通读
  var num
  num=1
 
  function f1(){
      var num   //函数内部num和外部互不影响
      num=2
      console.log(num)  //2
  }
  function f2(){ 
      console.log(num)  //1
  }
  f1();
  f2();
*/

(2)声明式函数

对函数进行提前声明,并且直接赋值为一个函数

javascript 复制代码
// 1.会正常执行吗?
foo(); 
function foo() {
  console.log("Hello, world!");
}

// 2.会抛出错误吗?为什么?
bar();
var bar = function() {
  console.log("Bar function");
};

function outer() {
  inner();  // 3.这里会怎样?
  var inner = function() {
    console.log("Inner function");
  };
}
outer();

解答:

javascript 复制代码
/*
    1
    函数声明会在预解析阶段被提升到作用域顶部
    正常执行
*/

/*
    2
    var bar
    bar()
    bar=function(){
        console.log("Bar function");
    };
    会抛出错误
    因为在执行时bar还没有被定义
    尽管变量声明会被提升
    但是函数表达式的赋值不会提升
    因此在赋值之前调用会失败。
*/

/*
    3
    这里会抛出错误
     function outer() {
        var inner
        inner(); // 此时inner定义未赋值时undefined
        inner= function () {
             console.log("Inner function");
        };
     }
     outer();
 
*/

下一篇:11.作用域及作用域链-CSDN博客

相关推荐
共享家952716 小时前
搭建 AI 聊天机器人:”我的人生我做主“
前端·javascript·css·python·pycharm·html·状态模式
摘星编程18 小时前
OpenHarmony环境下React Native:自定义useTruncate文本截断
javascript·react native·react.js
Duang007_18 小时前
【LeetCodeHot100 超详细Agent启发版本】字母异位词分组 (Group Anagrams)
开发语言·javascript·人工智能·python
2601_9498683620 小时前
Flutter for OpenHarmony 电子合同签署App实战 - 主入口实现
开发语言·javascript·flutter
m0_7482299920 小时前
Vue2 vs Vue3:核心差异全解析
前端·javascript·vue.js
xiaoxue..20 小时前
React 手写实现的 KeepAlive 组件
前端·javascript·react.js·面试
摘星编程20 小时前
在OpenHarmony上用React Native:自定义useHighlight关键词高亮
javascript·react native·react.js
2601_9496130221 小时前
flutter_for_openharmony家庭药箱管理app实战+用药知识详情实现
android·javascript·flutter
一起养小猫21 小时前
Flutter for OpenHarmony 实战 表单处理与验证完整指南
android·开发语言·前端·javascript·flutter·harmonyos
xcs194051 天前
前端 项目构建问题 \node_modules\loader-runner\lib\loadLoader.js
开发语言·前端·javascript