前端周记20190211-20190215
栏目: JavaScript · 发布时间: 6年前
内容简介:1、静态公有方法MyObject在私有作用域中在原型上挂载了一个公有方法,可以访问私有作用域中的变量。思考:原型上的函数的作用域含有被添加时的作用域。
1、静态公有方法
(function(){
var privateVariable=10;
function privateFunction(){
return false;
}
MyObject=function(){}
MyObject.prototype.publicMethod=function(){
privateVariable++;
return this;
}
})();
var a=new MyObject();
console.log(a.publicMethod());
MyObject在私有作用域中在原型上挂载了一个公有方法,可以访问私有作用域中的变量。
思考:原型上的函数的作用域含有被添加时的作用域。
2、js运行机制(Event Loop)
分为主线程和任务队列,主线程为空时,会读取任务队列中的事件(代码)。
任务队列是一个事件队列,只要指定过回调函数的事件在事件发生时就会进入任务队列。
回调函数:会被主线程挂起来的代码,异步任务必须指定回调函数。
settimeout和setInterval是到设置的事件后才触发回调函数,也就是添加到任务队列中。这里设置的时间是相对于在下一轮事件循环开始时的时间的间隔。这个时间是js执行到settimeout这个语句开始计算。h5中对时间标准化,最小4ms,不足则补齐
通过阅读Promise/A+规范,可以得知异步的实现可分为两个机制,分别是macro-task和micro-task。
Macrotasks包括: script(整体代码)、setTimeout, setInterval, setImmediate, I/O, UI Rendering;
Microtasks包括: process.nextTick, Promise, Object.observe, MutationObserver。
Macrotasks、Microtasks执行机制:
1.主线程执行完后会先到micro-task队列中读取可执行任务
2.主线程执行micro-task任务
3.主线程到macro-task任务队列中读取可执行任务
4.主线程执行macro-task任务
5....转到Step 1
这里注意的是,UI Rendering是在micro-task之后执行,需要在UI渲染之前执行的逻辑,一般采用micro-task异步回调方式进行调用
5、说明this几种不同的使用场景
作为构造函数执行
作为对象属性执行
作为普通函数执行(window)
call、apply、bind
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网
猜你喜欢:- 前端科普系列(三):CommonJS 不是前端却革命了前端
- 前端科普系列(三):CommonJS 不是前端却革命了前端
- 前端技术演进(三):前端安全
- 【前端优化】前端常见性能优化
- 【前端学习笔记】前端安全详解
- 前端监控和前端埋点
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
基于MVC的JavaScript Web富应用开发
麦卡劳(Alex MacCaw) / 李晶、张散集 / 电子工业出版社 / 2012-5 / 59.00元
《JavaScript Web 富应用开发》Developing JavaScript Web Applications是 Alex MacCaw 的新作(由O'Reilly出版发行),本书系统而深入的讲解了如何使用最前沿的Web技术构建下一代互联网富应用程序。作者 Alex MacCaw 是一名Ruby/JavaScript 程序员,在开源社区中很有名望,是Spine框架的作者,同时活跃在纽约、......一起来看看 《基于MVC的JavaScript Web富应用开发》 这本书的介绍吧!