[js]作用域链查找规则获取值和设置值

作用域链查找规则获取值和设置值

<script>
/**
 1.作用域链查找规则
    私有作用域出现的一个变量不是私有的,则往上一级作用域查找,上级作用域没有则继续向上级查找,一直找到window为止,如果window也没有了?
    1)如果是获取值,则报错
    2)如果是设置值,则相当于给window设置了一个属性

 2.js代码一旦报错,则不往下执行了.
 */

    function fn() {
        console.log(total); //获取值
        total = 100;        //设置值
    }

    fn();
    console.log(total);
</script>

原文地址:https://www.cnblogs.com/iiiiiher/p/8416959.html

时间: 2024-12-28 13:00:37

[js]作用域链查找规则获取值和设置值的相关文章

js 作用域链&amp;内存回收&amp;变量&amp;闭包

闭包主要涉及到js的几个其他的特性:作用域链,垃圾(内存)回收机制,函数嵌套,等等 一.作用域链:函数在定义的时候创建的,用于寻找使用到的变量的值的一个索引,而他内部的规则是,把函数自身的本地变量放在最前面,把自身的父级函数中的变量放在其次,把再高一级函数中的变量放在更后面,以此类推直至全局对象为止.当函数中需要查询一个变量的值的时候,js解释器会去作用域链去查找,从最前面的本地变量中先找,如果没有找到对应的变量,则到下一级的链上找,一旦找到了变量,则不再继续.如果找到最后也没找到需要的变量,则

【动画演示】:JS 作用域链不在话下

作者:Lydia Hallie译者:前端小智来源:dev 点赞再看,养成习惯 本文 GitHub https://github.com/qq44924588... 上已经收录,更多往期高赞文章的分类,也整理了很多我的文档,和教程资料.欢迎Star和完善,大家面试可以参照考点复习,希望我们一起有点东西. 本篇我们来看看啥是作用域以及作用域链,首先,来看看下面的代码: const name = "Lydia" const age = 21 const city = "San Fr

Js 作用域链(是指AO链)

1:参数 2:局部变量声明 3:函数声明 * 函数声明与函数表达式的区别 表达式必有返回值,把返回值(即匿名函数)赋给了一个变量. 此时 就是普通的赋值过程. ①.js并不是一句一句顺序执行的,先进行词法分析 This, 与 arguments 当一个函数运行的时候,函数内部能引用的变量有这么几种 AO.arguments.this 对于 arguments和this, 每个函数都有自己独有的arguments和this, 且不进行链式查找 arguments是什么? 答:1:arguments

js作用域链以及全局变量和局部变量

> [带var] > 在当前作用于中声明了一个变量,如果当前是全局作用域,也相当于给全局作用域设置了一个属性叫做a ```javascript //=>变量提升:var a; <=>window.a=undefined; console.log(a);//undefined var a = 12; console.log(a);//12 console.log(window.a);//window['a']在'全局作用域'中,我们声明了一个变量,相当于全局对象window增加

js作用域链中变量提前的问题

js訪问变量是从内到外,这条作用域链上面的每一个活动变量也是从内到外的.比方一个函数,首先由arguments和函数内部声明的变量,然后是外层的能訪问的变量.直至最后window全局对象.当出了这个函数,函数内部声明的活动对象就会销毁,所以外部滴根本无法訪问函数内部声明的对象的.之所以说js会把全部的变量提前也是针对不同的作用域的,在最外面.则是把全部的全局变量和全局的函数声明提前,在函数内部,则是先把函数内部声明的变量和函数提前

Js作用域链及变量作用域

要理解变量的作用域范围就得先理解作用域链 用var关键字声明一个变量时,就是为该变量所在的对象添加了一个属性. 作用域链:由于js的变量都是对象的属性,而该对象可能又是其它对象的属性,而所有的对象都是window对象的属性,所以这些对象的关系可以看作是一条链 链头就是变量所处的对象,链尾就是window对象 看下面的代码: function t() { var a; function t2() { var b; } } js中函数也是对象,所以变量a所在的对象是t,t又在window对象中,所以

JS作用域链

Js作用域与执行环境: 1. 作用域链: <1>用途:保证对执行环境有权访问的所有变量和函数的有序访问. <2>构成: a.作用域链的前端,始终都是当前执行代码所在环境的变量对象(如果这个环境是函数,则将其活动对象作为变量对象,活动对象在最开始时只包含一个变量,即arguments对象): b.下一个变量对象来自包含(外部)环境: c.最后一个对象,为全局执行环境的变量对象. <3>标识符解析:是沿着作用域链一级一级地搜索标识符的过程,始终从作用域链的前端开始,然后逐级

jQuery 之 模态编辑框实例(文本获取值与设置值)

代码 <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Title</title> <script src="jquery3.js"></script> <style> .modal{ position: fixed; top: 50%; left:

利用反射获取字段并获取值或者设置值

package Reflect; import java.lang.reflect.Field;class User{ public String account; public String password;}class Student extends User{ public int age; public String name; private String sex; public Student() { System.out.println("调用无参构造器创建对象");