前端进阶必读:《JavaScript核心技术开发解密》核心提炼二
前言
最近读勒基本关于前端的数据《JavaScript核心技术开发解密》,《webpack从入门到进阶》...这几本书帮助到我更好的理解JS、webpack在前端技术领域中的作用。以前可能更多的是知道怎么使用,但从未从更深的层面去思考他们是如何运作,为什么会产生这种特性,等等...
这本书先从《JavaScript核心技术开发解密》开始讲解,分为两篇讲完,读完本篇你能学到:
前端进阶必读:《JavaScript核心技术开发解密》核心提炼一
前端进阶必读:《JavaScript核心技术开发解密》核心提炼三
@
五、作用域与作用域链
在JS中,作用域是用来规定变量/函数可访问的规则
5.1作用域
5.1.1全局作用域
在非严格模式,未定义的变量/函数会自动的变成window的属性;
在实践中,尽可能的减少使用全局变量/函数,为了减少协作冲突,提高性能(全局作用域在作用域链的链尾)
5.1.2函数作用域
在ES6之前,es是没有块级作用域的,所以一定是在函数环境中才能生成新作用域
案例:
var arr = [1,2,3];
for(var i = 0; i < arr.length; i++) {
console.log(i);
}
console.log(i); // 4
5.1.3模拟块级作用域
A: 利用函数产生
var arr = [1,2,3];
// 匿名自执行函数执行会产生函数作用域
(function () {
for(var i = 0; i < arr.length; i++) {
console.log(i);
}
})()
// 匿名自执行函数的几种写法
(function(){})() // 最常用
*function(){}()
-function(){}()
!function(){}()
重要知识来了:
在ES中,往往通过自执行函数来实现模块化;
模块化是非常重要的开发思维
5.2作用域链
scopeChain是当前执行环境的上层执行环境的一系列变量对象组成,串联作用域。
案例:
var a = 20;
function test () {
var b = a + 10;
function innerTest () {
var c = 10;
return b + c;
}
return innerTest;
}
test();
/**
以上代码innerText的作用域链如下:
innerTestEC = {
VO: {...}, // 变量对象
scopeChain: [VO(innerTest),VO(test),VO(window)], // 好好看这里!
this: {...}
}
**/
6、闭包
到了这里,就到了前端是个人都听过的东西了,极其重要的特性!!!
6.1概念
闭包是一种特殊对象
由两部分组成:
- 执行上下文A
- 该执行上下文创建的函数B
B执行时,刚问了A中的值,闭包即产生
6.2闭包与垃圾回收机制
正常的上下文运行后,内部的内容都是去了引用而被垃圾回收,但闭包导致A的变量被B持有,阻止了垃圾回授(所以也会导致性能问题)
6.3闭包与作用域链
- 作用域链在编译中以确定规则,在执行中产生
- 函数调用栈在执行中才确定
6.4 在chrome开发工具中能够观察函数调用栈,作用域链与闭包
6.5 应用闭包
6.5.1 循环、setTtimeOut与闭包
案例:
利用闭包的知识,修改下面这段代码,让代码的执行结果为隔秒输出1,2,3,4,5
for(var i = 0; i <= 5; i++) {
setTimeOut(function timer() {
console.log(i);
},i * 1000 )
}
利用闭包修改
for(var i = 0; i <= 5; i++) {
(function (i) {
setTimeOut(function timer() {
console.log(i);
},i * 1000 )
})(i)
}
或者
for(var i = 0; i <= 5; i++) {
setTimeOut((function (i) {
return function timer () {
console.log(i);
}
})(i), i * 1000 )
}
6.5.2单例模式与闭包
在JS中有许多编程思维,其中单例模式时实践中最常用的模式之一,而它的实现与闭包息息相关
七、this
鸡婆一下:来到这个很多人都搞不清楚this指向的问题了,看完这一样相信你会豁然开朗,因为this指向其实比想象中要简单得多。
7.1 this指向
当函数被调用执行时,函数进入创建阶段(前面有讲到),此时会生成变量对象,this确定指向,还做了XXX,随后进入执行阶段。
案例:
var a = 10;
var obj = {
a : 20
}
function fn () {
console.log(this.a);
}
fn(); // 10 (方法时一定有调用者的,这里省略是因为在非严格模式下,自动变成window.fn())
fn.call(obj); // 20 因为fn函数的执行上下文this被修改成obj对象
7.2 call/apply/bind显示绑定this
相信很多人都知道这三个函数的作用,call/apply几乎一样,知只是传参规则不同,bind是先绑定,返回绑定后的方法,未执行。
| call | apply | bind |
|---|---|---|
| 直接传参 | 数组传参 | 直接传参(不立即执行,而是返回修改this后的方法) |
ES6中的箭头函数是不能改变this的,使用以上三个方法也不能(先预告,后面会讲到)
八、面向对象
8.1.1
// 构造函数与普通函数并无区别,首字母大写是约定的习惯,new关键字才是将构造方法变得与众不同
var Person = function (name, age) {
this.name = name;
this.age = age;
}
Person.protptype.getName = function () {
return this.name
}
8.1.2 new关键字
下面我们来模拟一边new关键字的作用
function New (constructFunc) {
// 生命中间对象,最后作为返回的实例,相当于let obj = New(Obj); => obj = res
var res = {};
if(constructFunc.prototype !== null) {
// 将实例的原型指向构造函数的原型
res.__proto__ = constructFunc.prototype;
}
// ret为该构造函数执行的结果,将构造函数的this改为执行res
var ret = constructFunc.apply(res, Array.prototype.slice.call(arguments, 1));
// 如果构造函数有返回值,则直接返回
if((typeof rest === "object" || typeof ret === "function") && ret !== null) {
return ret;
}
// 否则返回该实例
return res;
}
总结:
- 先创建空的、新的实例对象(New(func)返回的对象)
- 将实例对象的原型指向构造函数的原型
- 将构造函数的this改为指向实例对象
- 最后返回该实例对象(如果构造函数本身有返回则直接返回)
8.1.3更简单的原型写法
function Person () {};
Person.prototype.getName = function () {};
Person.prototype.getAge = function () {};
// 简化
Person.prototype = {
construor : Person, // 此时Person.protottype指向了新的对象,所以会导致原型对象丢失,所以加上此行
getName : function () {},
getAge: function () {},
}
8.1.4实例方法、原型方法、静态方法
function Foo () {
this.bar = fucntion () { // 实例方法
return 'bar in Foo';
}
}
Foo.bar = function () {return 'static'} // 静态方法
Foo.prototype.bar = function () {return 'prototype'} // 原型方法
前端进阶必读:《JavaScript核心技术开发解密》核心提炼二的更多相关文章
- 高德地图 JavaScript API 开发系列教程(二)
上节简单介绍高德地图JavaScript API及网页中基本地图展示.有了地图后我们可以用来做什么?有人说离我最近的超市在哪里,我怎么去?别急,这些功能我们后面都会慢慢实现.今天为大家详细讲解如何在地 ...
- 前端开发:面向对象与javascript中的面向对象实现(二)构造函数与原型
前端开发:面向对象与javascript中的面向对象实现(二)构造函数与原型 前言(题外话): 有人说拖延症是一个绝症,哎呀治不好了.先不说这是一个每个人都多多少少会有的,也不管它究竟对生活有多么大的 ...
- 我在阿里这仨月 前端开发流程 前端进阶的思考 延伸学习的方式很简单:google 一个关键词你能看到十几篇优秀的博文,再这些博文中寻找新的关键字,直到整个大知识点得到突破
我在阿里这仨月 Alibaba 试用期是三个月,转眼三个月过去了,也到了转正述职的时间.回想这三个月做过的事情,很多很杂,但还是有重点. 本文谈一谈工作中遇到的各种场景,需要用到的一些前端知识,以及我 ...
- [前端进阶课] 构建自己的 webpack 知识体系
webpack webpack 最出色的功能之一就是,除了 JavaScript,还可以通过 loader 引入任何其他类型的文件. Webpack 核心概念: Entry(入口):Webpack 执 ...
- Javascript模块化开发,使用模块化脚本加载工具RequireJS,提高你代码的速度和质量。
随着前端JavaScript代码越来越重,如何组织JavaScript代码变得非常重要,好的组织方式,可以让别人和自己很好的理解代码,也便于维护和测试.模块化是一种非常好的代码组织方式,本文试着对Ja ...
- 前端js之JavaScript
知识预览 一小知识 二 JavaScript的基础 BOM对象 DOM对象 实例练习 js拓展 小知识 核心(ECMAScript) 文档对象模型(DOM) Document object model ...
- 前端基础之JavaScript day51
前端基础之JavaScript JavaScript概述 JavaScript的历史 1992年Nombas开发出C-minus-minus(C--)的嵌入式脚本语言(最初绑定在CEnvi软件中) ...
- 前端工程师(JavaScript)在业余时间如何提高自身能力
1.前端工程师(JavaScript)在业余时间如何提高自身能力? https://www.zhihu.com/question/40186398?sort=created 2.前端开发工程师必读书籍 ...
- 腾讯Web前端开发框架JX(Javascript eXtension tools)
转自:Web前端开发-Web前端工程师 » 腾讯Web前端开发框架JX(Javascript eXtension tools) JX – Javascript eXtension tools 一个类似 ...
随机推荐
- 年薪50W京东软件测试工程师的成长路——我们都曾一样迷茫
这两天和朋友谈到软件测试的发展,其实软件测试已经在不知不觉中发生了非常大的改变,前几年的软件测试行业还是一个风口,随着不断地转行人员以及毕业的大学生疯狂地涌入软件测试行业,目前软件测试行业“缺口”已经 ...
- 深入探究JVM之对象创建及分配策略
@ 目录 前言 正文 一.对象的创建方式 二.对象的创建过程 对象在哪里创建 分配内存 对象的内存布局 三.对象的访问定位 四.判断对象的存活 对象生死 回收方法区 引用 对象的自我拯救 五.对象的分 ...
- Linux企业运维人员最常用命令汇总
本文目录 线上查询及帮助命令 文件和目录操作命令 查看文件及内容处理命令 文件压缩及解压缩命令 信息显示命令 搜索文件命令 用户管理命令 基础网络操作命令 深入网络操作命令 有关磁盘与文件系统的命令 ...
- TCP通信---文件上传案例、多线程文件上传
目前大多数服务器都会提供文件上传的功能,由于文件上传需要数据的安全性和完整性,很明显需要使用TCP协议来实现. TCP通信需要创建一个服务器端程序和一个客户端程序,实现客户端向服务器端上传文件 代码实 ...
- Python编程入门(第3版) PDF|百度网盘下载内附提取码
Python编程入门(第3版)是图文并茂的Python学习参考书,书中并不包含深奥的理论或者高级应用,而是以大量来自实战的例子.屏幕图和详细的解释,用通俗易懂的语言结合常见任务,对Python的各项基 ...
- Linux的VMWare中Centos7的安装
Windows平台下VMWare 14安装Centos 7 一.虚拟机硬件配置 1.选择创建新的虚拟机: 2.选择自定义(高级)进行自定义配置,单击下一步: 3.选择虚拟机硬件兼容性为默认,单击下一步 ...
- 创建githup远程库并关联
第一种方法:远程new仓库时直接勾选初始化仓库,然后克隆到本地即可(注:本地对应层不可再初始化仓库git init).克隆下来的仓库已经与远程库建立了管理git removte 第二种方法:本地下面有 ...
- 卷积神经网络 part1
[任务一]视频学习心得及问题总结 根据下面三个视频的学习内容,写一个总结,最后列出没有学明白的问题. [任务二]代码练习 在谷歌 Colab 上完成代码练习,关键步骤截图,并附一些自己的想法和解读. ...
- 4.深入k8s:容器持久化存储
从一个例子入手PV.PVC Kubernetes 项目引入了一组叫作 Persistent Volume Claim(PVC)和 Persistent Volume(PV)的 API 对象用于管理存储 ...
- requests-html库轻体验-HTMLSession下载表情包
requests-html实战,HTMLSession下载斗图啦最新表情包 前言 在这篇文章之前,我写了requests入门实践02_下载斗图拉最新表情包用正则表达式提取url,来下载斗图啦最新表情包 ...