前端周记20190211-20190215

news/2025/1/8 10:35:37

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几种不同的使用场景
作为构造函数执行:指向new生成的对象
作为对象属性执行:指向调用的对象
作为普通函数执行:指向调用的对象
作为回调函数执行:指向调用时的上下文
settimeout和setInterval:指向调用时的上下文即window
闭包:指向当前函数
箭头函数:指向定义时的上下文
call、apply、bind


http://www.niftyadmin.cn/n/639963.html

相关文章

windows下安装使用gmp

windows下的安装配置&#xff1a;https://blog.csdn.net/u012629110/article/details/51220727 使用&#xff1a; 添加头文件&#xff1a; #include <gmpxx.h> 编译必须链接相应的库&#xff1a; g mycxxprog.cc -lgmpxx -lgmp -o mycxxprog (1)gmp整数操作&#x…

dark gdk+visual c++2008在虚拟机中的运行问题

最近在开始学习做游戏&#xff0c;但是自己用的系统是ubuntu&#xff0c;所以就装了一个virtualbox,并且装了一个xp&#xff0c;于是就开始了游戏之路&#xff0c;但是我发现游戏之路是如此的坎坷&#xff0c;很多小问题&#xff0c;不过都能很快的解决&#xff0c;由于我用的是…

号码隐私保护,让用户数据更安全

常言道“出行靠滴滴&#xff0c;吃饭有饿了么”&#xff0c;在科技的时代&#xff0c;互联网平台赋予了生活更多的选择&#xff0c;一切正变得丰富、便捷。小雨淅淅沥沥地湿润着春天&#xff0c;如往常般打开手机&#xff0c;我突然发现一些APP悄然无息地有了些共同的变化&…

Wordpress博客安装异次元分享工具条的方法

异次元单篇文章顶部的分享工具条做的很美观&#xff0c;集成了新浪微博、腾讯微博、QQ空间、人人网等分享按钮&#xff0c;页面浏览数以及支付宝捐赠等功能。可惜的是没有分享出来&#xff0c;黑苹果博客分享高仿版&#xff0c;具体方法&#xff1a; 基于 eliteYang 的 Version…

第九十三课.向上转型

Java 转型问题其实并不复杂&#xff0c;只要记住一句话&#xff1a;父类引用指向子类对象。什么叫父类引用指向子类对象&#xff0c;父类定义的对象存放的子类的地址 向上转型&#xff1a;通俗地讲即是将子类对象转为父类对象。此处父类对象可以是接口 举个例子&#xff1a;有…

python 列表,数组,矩阵之间转换

# -*- coding: utf-8 -*- from numpy import *a1 [[1,2,3],[4,5,6]] #列表 print(a1 :,a1) #(a1 :, [[1, 2, 3], [4, 5, 6]])a2 array(a1) #列表 -----> 数组 print(a2 :,a2) #(a2 :, array([[1, 2, 3],[4, 5, 6]]))a3 mat(a1) #列表 ----> 矩阵 print(a3 :,a3)…

VS2017中设置程序默认以管理员身份运行权限

在Windows编程中&#xff0c;运行程序时出现错误&#xff0c;错误返回值为5&#xff0c;这表示程序运行的权限不够&#xff0c;在Visual Studio 2017 中设置程序以管理员身份运行的步骤是&#xff1a; 直接项目右键---属性---连接器---清单文件---uac执行级别 选择requireAdmi…

NYOJ_515_完全覆盖_剖析大神的代码

大神的解题报告&#xff1a;http://hi.baidu.com/newmyl/item/afc7cb0ef6ef5b7dbee97e07 1、当高度&#xff08;h&#xff09;和宽度(w)为奇数时&#xff1a; areah*w; 骨牌面积&#xff1a;2 h*w / 2!0 -> 不能用骨牌覆盖 2、记f[i][s1]为第i-1行全满且第i行状态为s1时的种…