觉醒 闭包/this
两条非常重要的知识点
首先上题
var a = '322'
var preview = function() {
var a = '123'
console.log(a, this, this.a)
} preview() // 123 window 322 //每个函数在被调用的时候
//1.自动获取两个特殊变量 arguments类数组对象 和this对象。内部函数在搜索这两个变量的时候,只会搜索到其变量对象为止。不会访问其他外部函数作用域中的这两个变量。 除非把外部函数作用域中的this保存起来,在一个闭包能够访问的变量里
//2.会创建一个执行环境及相应的作用域链。使用arguments和其他命名参数的值来初始化函数的活动对象。 //函数执行完
//用有闭包的函数执行完后 其执行环境的作用域链会被销毁(但是闭包的作用域链还在引用这个活动对象) 所以活动对象仍然保留。直到闭包被销毁
1.重点: this.a = 322而不是123 因为 this.a 是对象拿属性的方法。不是拿变量
var b = 'global'
var preview = function() {
var b = 'part'
console.log('ground',"//", this,"//", this.b)
return function() {
console.log('floor',"//",b,"//", this,"//", this.b)
}
}
preview()()
//window global
// part window global
//证明了 this对象在全局函数 和匿名函数中都指向window
2.函数的作用域是在函数声明的时候决定的(调用自由变量也是在函数作用域内开始,与执行环境无关)
觉醒 闭包/this的更多相关文章
- 《Web 前端面试指南》1、JavaScript 闭包深入浅出
		
闭包是什么? 闭包是内部函数可以访问外部函数的变量.它可以访问三个作用域:首先可以访问自己的作用域(也就是定义在大括号内的变量),它也能访问外部函数的变量,和它能访问全局变量. 内部函数不仅可以访问外 ...
 - 干货分享:让你分分钟学会 JS 闭包
		
闭包,是 Javascript 比较重要的一个概念,对于初学者来讲,闭包是一个特别抽象的概念,特别是ECMA规范给的定义,如果没有实战经验,很难从定义去理解它.因此,本文不会对闭包的概念进行大篇幅描述 ...
 - 深入浅出JavaScript之闭包(Closure)
		
闭包(closure)是掌握Javascript从人门到深入一个非常重要的门槛,它是Javascript语言的一个难点,也是它的特色,很多高级应用都要依靠闭包实现.下面写下我的学习笔记~ 闭包-无处不 ...
 - javascript之闭包理解以及应用场景
		
半个月没写博文了,最近一直在弄小程序,感觉也没啥好写的. 之前读了js权威指南,也写了篇博文,但是实话实说当初看闭包确实还是一头雾水.现在时隔一个多月(当然这一段时间还是一直有在看闭包的相关知识)理解 ...
 - js闭包 和 prototype
		
function test(){ var p=200; function q(){ return p++; } return q; } var s = test(); alert(s()); aler ...
 - js闭包for循环总是只执行最后一个值得解决方法
		
<style> li{ list-style: none;width:40px;height: 40px;text-align:center;line-height: 40px;curso ...
 - JavaScript学习笔记(二)——闭包、IIFE、apply、函数与对象
		
一.闭包(Closure) 1.1.闭包相关的问题 请在页面中放10个div,每个div中放入字母a-j,当点击每一个div时显示索引号,如第1个div显示0,第10个显示9:方法:找到所有的div, ...
 - 带你一分钟理解闭包--js面向对象编程
		
上一篇<简单粗暴地理解js原型链--js面向对象编程>没想到能攒到这么多赞,实属意外.分享是个好事情,尤其是分享自己的学习感悟.所以网上关于原型链.闭包.作用域等文章多如牛毛,很多文章写得 ...
 - 如何设计一门语言(七)——闭包、lambda和interface
		
人们都很喜欢讨论闭包这个概念.其实这个概念对于写代码来讲一点用都没有,写代码只需要掌握好lambda表达式和class+interface的语义就行了.基本上只有在写编译器和虚拟机的时候才需要管什么是 ...
 
随机推荐
- Educational Codeforces Round 72 (Rated for Div. 2)C(暴力)
			
#define HAVE_STRUCT_TIMESPEC#include<bits/stdc++.h>using namespace std;char s[200007];int a[20 ...
 - 新增6 n个骰子的点数
			
/* * * 面试题43:n个骰子的点数 * 把n个骰子扔在地上,所有骰子朝上一面的点数之和为s. * 输入n,打印出s的所有可能的值出现的概率. * */ #include <iostream ...
 - 63 滑动窗口的最大值    &&front(),back()操作前一定要判断容器的尺寸不能为0
			
给定一个数组和滑动窗口的大小,找出所有滑动窗口里数值的最大值.例如,如果输入数组{2,3,4,2,6,2,5,1}及滑动窗口的大小3,那么一共存在6个滑动窗口,他们的最大值分别为{4,4,6,6,6, ...
 - 498. (leetcode)对角线遍历
			
498. 对角线遍历 根据题目的图像看,主要有两种走法,第一种是向右上(顺时针方向),第二种是向左下(逆时针)走 我们设 x ,y初始为0,分别对应横纵坐标 现在分析右上(0,2) 为例:(注意右上的 ...
 - ActiveMQ--模式(队列模式/主题模式)
			
两种模式:队列模式/主题模式 pom.xml <dependency> <groupId>org.apache.activemq</groupId> <art ...
 - CSS - 伪类和伪元素
			
1. CSS3中 :Pseudo-classes 伪类 ::Pseudo-elements 伪元素 2. 为什么叫伪类和伪元素? 伪类的效果可以通过添加一个实际的类来达到,而伪元素的效果则需要通过添加 ...
 - mac允许安装任何来源的软件
			
如果在“系统偏好设置”--“安全性与隐私”--“通用”版面没有像下面的选项.那么请打开终端,使用命令行操作,之后重新进刚刚的设置界面,会出现“任何来源”的选项. 命令行:(请复制使用) sudo sp ...
 - 【快学springboot】在springboot中写单元测试
			
前言 很多公司都有写单元测试的硬性要求,在提交代码的时候,如果单测通不过或者说单元测试各种覆盖率不达标,会被拒绝合并代码.写单元测试,也是保证代码质量的一种方式. junit单元测试 相信绝大多数的J ...
 - C#中as用法---转载
			
转载 jiang13824690 发布于2018-07-24 11:19:00 阅读数 3302 收藏 展开 在程序中,进行类型转换时常见的事,C#支持基本的强制类型转换方法,例如 Object o ...
 - shell脚本中执行sql脚本(mysql为例)
			
1.sql脚本(t.sql) insert into test.t value ("LH",88); 2.shell脚本(a.sh 为方便说明,a.sh与t.sql在同一目 ...