>/favicon.ico" width="16" height="16" /> 添加到上图位置就ok了。然后去首页刷新一下,即可。...如果有没有获取的请不要惊慌,有可能是网络导致ico没有获取成功,也有可能是对方网站根目录是没有favicon.ico图标文件,联系对方放一个就ok,favicon.ico图标一般32*32的分辨率即可。...教程结束,以下是杨小杰blog的友链效果:
1、icon命名为favicon.ico放在项目的位置:src/assets/favicon.ico 2、在index.html中写入: <link rel="shortcut icon" type="image/x-icon" href="src/assets/favicon.<em>ico</em>...: config.build.index, template: 'index.html', favicon: path.resolve('src/assets/favicon.<em>ico</em>..., template: 'index.html', inject: true, favicon: path.resolve('src/assets/favicon.<em>ico</em>
题外话:最近面试一直被问到作用域链的问题,所以还是要深入透彻的学习一下这两个概念。 作用域链 在红宝书中对作用域链的描述有这么一段话:当代码在一个环境中执行时,会创建变量对象的一个作用域链。...作用域链的用途是保证对执行环境有权访问的所有变量和函数的有序访问。作用域链的前端始终是当前执行的代码所在环境的变量对象。如果这个环境是函数,则将其活动对象作为变量对象。...作用域链的下一个变量对象来自包含环境,而在下一个变量对象则来自下一个包含环境。这样一直延续到全局执行环境;全局执行环境的变量对象始终都是作用域链中的最后一个对象。...在创建compare()函数时,会创建一个预先包含全局变量对象的作用域链,这个作用域链会被保存在内部的[[Scope]]属性中。...作用域链知识总结 当代码在一个环境中执行时,都会创建一个作用域链。 作用域链的用途是保证对执行环境有权访问的所有变量和函数的有序访问。整个作用域链的本质是一个指向变量对象的指针列表。
一、JavaScript 作用域链 1、作用域 在 JavaScript 中 , 任何代码都有 作用域 , 全局作用域 : 在 标签中 或者 js 脚本中 定义的变量 属于 全局作用域...之前使用 var 关键字在 {} 代码块 中定义的变量 , 取决于 代码块位置 , 代码块在全局作用域 则 该变量属于全局作用域 , 代码块在 局部作用域 则该变量属于 局部作用域 ; 2、作用域链 如果在...确定取哪个值 , 这种作用域结构 称为 " 作用域链 " ; 内部函数 , 外部函数 , 全局变量 中 , 定义的变量名称 可能是相同的 , 给定一个变量名 , 需要从作用域链中具体查找 作用域链 是...; 3、作用域链变量查找机制 在 JavaScript 代码中 的 嵌套作用域 中 , 查找 变量 或 函数 的 机制就是 作用域链 的 链式查找机制 ; 内部函数 在 访问 指定名称的 变量时 ,...没有该变量 , 则报 " 变量未定义 " 错误 ; 二、代码示例 - 作用域链 在下面的代码中 : 首先 , 在 全局作用域 中定义 num 变量 , 该变量的 作用域 属于 全局作用域 ; 然后 ,
原型与原型链: 每个函数都有 prototype 属性,除了 Function.prototype.bind() ,该属性指向原型。...对象可以通过 __proto__ 来寻找不属于该对象的属性, __proto__ 将对象连接起来组 成了原型链。...__proto__ 作用域与作用域链: 作⽤域就是变量与函数的可访问范围,即作⽤域控制着变量与函数的可⻅性和⽣命周期,也可理解为该上下⽂中声明的变量和声明的作⽤范围,可分为块级作⽤域和函数作⽤域。...作⽤域链可以理解成包含⾃身变量对象和上级变量对象的列表,通 过 [[Scope]] 属性查找上级变量。...作⽤域链的作⽤是保证执⾏环境⾥有权访问的变量和函数是有序的,作⽤域链的变量只能向上访问,变量访问到 window 对象即被终⽌,作⽤域链向下访问变量是不被允许的。
作用域与作用域链 通常来说,一段程序代码中所用到的名字并不总是有效或可用的,而限定这个名字的可用性的代码范围就是这个名字的作用域scope。...如果一个变量或者其他表达式不在当前的作用域,则将无法使用。作用域也可以根据代码层次分层,以便子作用域可以访问父作用域,通常是指沿着链式的作用域链查找,而不能从父作用域引用子作用域中的变量和引用。...全局作用域 直接声明在顶层的变量或方法就运行在全局作用域,借用函数的[[Scopes]]属性来查看作用域,[[Scopes]]是保存函数作用域链的对象,是函数的内部属性无法直接访问但是可以打印来查看。...也是局部作用域 作用域链 var a = 1; (function s(){ var a = 2; console.log(a); // 2 })(); console.log(a);...作用域、localContext作用域、Global作用域,总结来说,当需要使用函数或者变量时,如果在当前作用域中没有查到值,就会向上级作用域去查,直到查到全局作用域,这样一个查找过程形成的链条就叫做作用域链
总之一句话: 函数的作用域在函数定义的时候就决定了 函数会沿着作用域链去查找变量。 那么为什么 JavaScript 是静态作用域呢?JavaScript 引擎是怎么处理函数的呢?...对于每个执行上下文,都有三个重要属性: 变量对象(Variable object,VO) 作用域链(Scope chain) this JavaScript 引擎会沿着作用域链去查找变量。...作用域链是如何产生?我们应该先了解 JavaScript 引擎 在创建 执行上下文 的具体处理过程。..., 用 arguments 创建活动对象, 初始化活动对象,即加入形参、函数声明、变量声明, 将活动对象压入 checkscope 作用域链顶端(执行至此,该函数的作用域链才完整)。...这样由多个执行上下文的变量对象构成的链表就叫做作用域链。 由上可知,作用域链是由 变量对象/活动对象 构成的。 活动变量 变量对象是与执行上下文相关的数据作用域,存储了在上下文中定义的变量和函数声明。
下面就要借助JS的作用域链来更好的理解作用域了。 在此之前,先要明确个概念,即执行环境和作用域是两个完全不同的概念。 函数的每次调用都有与之紧密相关的作用域和执行环境。...在这个阶段,作用域链会被初始化,this的值也会被最终确定。在执行阶段,代码被解释执行。...当代码在一个环境中执行时,会创建变量对象的一个作用域链(scope chain)。作用域链的用途是保证对执行环境有权访问的所有变量和函数的有序访问。...作用域链包含了执行环境栈中的每个执行环境对应的变量对象。通过作用域链,可以决定变量的访问和标识符的解析。 注意:全局执行环境的变量对象始终都是作用域链的最后一个对象。...需要注意的是:内部环境可以通过作用域链访问所有的外部环境,但是外部环境不能访问内部环境中的任何变量和函数。 标识符解析(变量名或函数名搜索)是沿着作用域链一级一级地搜索标识符的过程。
当代码在一个环境中执行时,会创建变量对象的一个作用域链。作用域链的用途,是保证对执行环境有权访问的所有变量和函数的有序访问。...当fun1执行的时候创建了一个作用域链,所以fun1有两个变量对象,一个是自己,一个是全局环境的变量对象window。fun1可以在函数内部访问变量a,因为fun1所在的作用域链可以找到变量a。...fun1; 局部环境fun1有一个变量b和一个函数fun2,但是fun1可以访问全局环境的变量a; 局部环境fun2有一个变量c,但是fun2可以访问fun1环境中的变量b和全局环境的变量a; 这就是作用域链...,作用域链中的内部环境可以通过作用域链访问所有的外部环境,但外部环境不能访问内部环境中的任何变量和函数。...作用域链中,每一个局部环境都会首先寻找自身环境中的属性和方法,搜索到了就停止寻找,没有找到再向上搜索直到最外层window还搜索不到就报错。 (完)
每个运行期上下文都有自己的作用域链,用于标识符解析,当运行期上下文被创建时,而它的作用域链初始化为当前运行函数的[[Scope]]所包含的对象。...---- 例子 举一个作用域链的例子。...---- 延长作用域链 有些语句可以在作用域链的前端临时增加一个变量对象,该变量对象会在代码执行后被移除。有两种情况下会发生这种现象。...---- 代码优化 从作用域链的结构可以看出,在运行期上下文的作用域链中,标识符所在的位置越深,读写速度就会越慢。...理解 JavaScript 作用域和作用域链 JavaScript 深入浅出-慕课网
一、作用域分为块级作用域、全局作用域、函数作用域作用域就是一个独立的地盘,让变量不会外泄、暴露出去。也就是说作用域最大的用处就是隔离变量,不同作用域下同名变量不会有冲突。...二、作用域链当前作用域没有定义的变量,这成为自由变量 。需要向父级作用域寻找(注意:这种说法并不严谨,作用域中取值,这里强调的是“创建”,而不是“调用”,切记切记,其实这就是所谓的"静态作用域"。)。
作用域与作用域链本应该是一个非常简单的概念。...作用域链 首先我们要明确的一点是,作用域和作用域链是不同的。 作用域是一套规则。 而作用域链则是在代码执行过程中,会动态变化的一条索引路径。...我们知道函数在调用激活时,会开始创建对应的执行上下文,在执行上下文生成的过程中,变量对象,作用域链,以及this的值会分别被确定。之前一篇文章我们详细说明了变量对象,而这里,我们将详细说明作用域链。...作用域链,是由当前环境与上层环境的一系列变量对象组成,它保证了当前执行环境对符合访问权限的变量和函数的有序访问。 为了帮助大家理解作用域链,我我们先结合一个例子,以及相应的图示来说明。...scopeChain[0]为作用域链的最前端,而数组的最后一项,为作用域链的最末端,所有的最末端都为全局变量对象。
作用域 [[scope]],函数定义时自动生成的一个隐式属性,是用来存储函数作用域链 Scope Chain的容器。作用域链是用来存储函数执行上下文 AO和全局执行上下文 GO的容器。...函数被定义时,系统会为函数生成[[scope]],[[scope]]中保存该函数的作用域链,并从该作用域链的起始位置开始存储当前环境的作用域链。...函数被定义后&将要执行前会生成函数本身的AO,并将其插入作用域链的起始位置。...,并将GO插入到作用域链的起始位置。...函数a被执行时,此时函数b也被定义,函数b的[[scope]]也在此时生成,其中存储函数b的作用域链,并将当前环境的作用域链插入函数b作用域链的起始位置,即函数a的AO和GO。
从这个逻辑上来看,所有以区块链名义的ICO都是一场十足的骗局。 人们投身区块链的创富洪流,从根本上来看是互联网红利落幕带来的恐慌的延续。...正是因为这种情况的存在,所以我们看到很多的区块链项目到最后还是要走上发币或者ICO的道路。 为什么?...所以,千万不要想着借助区块链技术的风口进行所谓的ICO,这既是对自己的不负责,同样也是对行业的不负责。 避免区块链陷入ICO的陷阱,其中很重要的一点就是要找到区块链技术与传统行业的结合点。...打着区块链的幌子进行ICO的项目99%都是一场骗局,他们发展到最后还是要回到数字货币的邪路上。...最后,再说一句,所有以区块链名义的ICO都是耍流氓。
这表明函数内部的变量i与循环变量i不在同一个作用域,有各自单独的作用域。 作用域链 1.什么是自由变量 首先认识一下什么叫做 自由变量 。...function fn() { var b = 200 console.log(a) // 这里的a在这里就是一个自由变量 console.log(b) } fn() 2.什么是作用域链...再一层一层向上寻找,直到找到全局作用域还是没找到,就宣布放弃。这种一层一层的关系,就是 作用域链 。...function F1() { var b = 200 function F2() { var c = 300 console.log(a) // 自由变量,顺作用域链向父作用域找...console.log(b) // 自由变量,顺作用域链向父作用域找 console.log(c) // 本作用域的变量 } F2() } F1() 3
作者 | 唐小引 责编 | 唐门教主 从火、疯到被一刀切,China’s ICO Ban 快狠准的一把火烧慌了国内无数人,也成为了国外热议的话题。...在舆论之中,墙倒众人推,鼓破万人捶,「夸夸其谈 ICO 有多乱然后总结出比特币是骗局」者众,而真正关心可以撼动银行业、货币以及商业合同本质的区块链技术的人却寡之寥寥。...从国内来看,8月28日,国内首家区块链电商“媒购”面世,这也是全球首家区块链电商;8月17日,“百度·长安新生·天风2017年第一期资产支持专项计划”获上交所批准,百度金融作为其技术服务商搭建了区块链服务端...另一些人则希望通过区块链来降低在线汇款的成本,区块链将允许微支付,让读者可以支付几美分来阅读报纸上的文章。...他说道,由于区块链具有独特的设置方式,即使某地发生了局部灾难,区块链的记录依然极有可能存在,因此可以通过查找区块链中的记录,在区块链的环境中进行验证,从而不需要回到记录本身的发起者。
中 {} 外面的作用域就是全局作用域,里面的变量和函数等其他资源可以在任意地方被访问到。...块级作用域 ES6新增的块级作用域:用let和const声明的变量才存在块级作用域,在该代码块外部访问不到该变量。在{ }中用let和const声明的变量就是一个块级作用域。...{ let a = 1; console.log(a) // 1 } console.log(a) // a is not defined 外部访问不到 二、作用域链 作用域链指的是各个作用域的嵌套关系和查找机制...function foo() { var b = 'foo中的b' function bar() { // 当前作用域中没有声明b则查找上一级作用域(创建该作用域的那个域),依次类推,直至到全局作用域...上下文中的代码在执行的时候会创建变量对象的一个作用域链(scope chain)。 希望本篇文章能够帮助到大家!
当代码在一个环境中执行时,会创建变量对象的一个作用域链(scope chain)来保证对执行环境有权访问的变量和函数的有序访问。 用一张图来解释作用域链的运行:由里向外执行。 ? ...每个运行期上下文都有自己的作用域链,用于标识符解析,当运行期上下文被创建时,而它的作用域链初始化为当前运行函数的[[Scope]]所包含的对象。 ...这些值按照它们出现在函数中的顺序被复制到运行期上下文的作用域链中。...该过程从作用域链头部,也就是从活动对象开始搜索,查找同名的标识符,如果找到了就使用这个标识符对应的变量,如果没找到继续搜索作用域链中的下一个对象,如果搜索完所有对象都未找到,则认为该标识符未定义。...总结 根据上述讲的作用域链的结构可以看出,定义的标识符的越深,那么读写的速度也就越慢,而全局变量总是处于作用域链的最末端,所以当变量解析的时候,查找全局变量是最慢的,所以在编写代码的时候要尽可能少的使用全局变量
如果作用域链上没有任何一个对象含有属性x,那么就认为这段代码的作用域链上不存在x,并最终抛出一个引用错误(ReferenceError)异常。 2....作用域链举例: 在js最顶层代码中(也就是不包括任何函数定义内的代码),作用域链由一个全局对象组成。...作用域链创建规则: 当定义一个函数时(注意,是定义的时候就开始了),它实际上保存一个作用域链。...当调用这个函数时,它创建一个新的对象来储存它的参数或局部变量,并将这个对象添加保存至那个作用域链上,同时创建一个新的更长的表示函数调用作用域的“链”。...因为每次调用外部函数的时候,作用域链都是不同的。内部函数在每次定义的时候都要微妙的差别---在每次调用外部函数时,内部函数的代码都是相同的,而且关联这段代码的作用域链也不相同。
作用域、作用域链也是面试中出镜率很高的问题之一java作用域java作用域,同时也是中最重要的基础概念之一。 ...今天我们将通过最简单实际的代码来展示函数作用域和全局作用域,在下篇文章中,我们将介绍块级作用域和暂时性死区。 ...作用域基本知识 简单来说,作用域就是用来规定变量的作用范围的,在任何语言当中都会有作用域的概念,在ES6以前,只有函数作用域和全局作用域,ES6之后又增加块级作用域。 ...foo函数中也无法访问bar函数中定义的变量b,其作用域链中(直到最上层的全局作用域中)也并不存在变量b,所以代码会报错 : b is not 简单来说就是,在执行某个函数时,如果需要取某个变量的值...变量作用域就是这样一层一层相套的关系,逐层寻找,这也就是被称之作用域链的原因。 在下篇文章中,我们将介绍块级作用域和暂时性死区的相关内容。 本文共 678 个字数,平均阅读时长 ≈ 2分钟
领取专属 10元无门槛券
手把手带您无忧上云