最开始查看nextTick这个方法的时候,眼瞎看成了nextClick...我还在疑问难道是下一次click之后处理事件... 然后用这个方法的时候,就只知道是用在DOM更新之后调用回调方法. 这时就产生了一堆疑问: 1)DOM更新后?难道修改数据之后,DOM没有及时更新,还有延迟?但是页面上看到的就是实时更新呀,难道还有什么猫腻? 2)它是怎么监听到DOM被更新了 3)它和异步的setTimeout.setInterval有没有关系? 深入了解后才发现里面有大学问... 在理解nextTick…
 壹 ❀ 引 通过结果倒推过程是我们常用的思考模式,我在上一篇学习promise笔记中,有少量关于promise执行顺序的例子,通过倒推,我成功让自己对于js执行机制的理解一塌糊涂,js事件机制,事件循环是面试常考的点,弄懂它们是贼有必要的. 回顾下我学习promise的心理历程: let p = Promise.resolve(1); p.then(resp => console.log(resp)); console.log(2); // 哦,原来如此,同步代码会先执行,先输出2,所以the…
首先我们先明确一点:JavaScript是一门单线程语言.单线程也就是说同一时间只能执行一个任务,所有的任务都必须排队顺序执行.那么如果一个任务耗时很长,阻塞了其它任务的执行,就会给用户造成不友好的体验.那么JS是如何解决这个问题的呢?(注:H5提出了Web Worker标准,允许JavaScript脚本创建多个线程,但是子线程完全受主线程控制,且不得操作DOM.所以,这个新标准并没有改变JavaScript单线程的本质.) 要搞清除这个问题,我们要明确知道同步任务和异步任务,异步执行机制,任务…
关于js执行机制,老早之前就一直想写篇文章做个总结,因为和js执行顺序的面试题碰到的特别多,每次碰到总是会去网上查,没有系统地总结,搞得每次碰到都是似懂非懂的感觉,这篇文章就系统的总结一下js执行机制. 任务队列 大家都知道js最大的特点就是单线程执行,这就是为什么js简单易学的一个重要原因,不需要考虑复杂的同步问题,但是单线程也会有一个问题,所有的任务在执行的过程中都必须等待前一个任务执行完成才能执行,这样就会带来一个效率的问题,为了解决这个问题,js将任务分为两种:同步任务和异步任务,同步任…
 壹 ❀ 引 最近在看前端进阶的系列专栏,碰巧看到了几篇关于JS事件执行机制的面试文章,因为我在之前一篇 JS执行机制详解,定时器时间间隔的真正含义 博文中也有记录JS执行机制,所以正好用于作为测试自己的理解情况,那么本文顺着题目来重新理一理思路,说说我对于题目的理解,扩充知识点. 本文站在你对于JS执行机制与定时器已经有所了解的前提下展开,若非如此,建议先了解相关概念会更好,那么本文开始.  贰 ❀ 一道变化的面试题  题目一: 说说以上代码输出什么? 没错,这只是一个非常简单的for循环,依…
浏览器中js执行机制学习笔记 RiverSouthMan关注 0.0772019.05.15 20:56:37字数 872阅读 291 同步任务 当一个脚本第一次执行的时候,js引擎会解析这段代码,并将其中的同步代码按照执行顺序加入执行栈中,然后从头开始执行.如果当前执行的是一个方法,那么js会向执行栈中添加这个方法的执行环境,然后进入这个执行环境继续执行其中的代码.当这个执行环境中的代码 执行完毕并返回结果后,js会退出这个执行环境并把这个执行环境销毁,回到上一个方法的执行环境.这个过程反复进…
js是单线程的,为什么可以执行异步操作呢? 这归结与浏览器(js的宿主环境)通过某种方式使得js具备了异步的属性. 区分进程和线程: 进程:正在运行中的应用程序.每个进程都自己独立的内存空间.例如:打开的浏览器就是一个进程. 线程:进程的子集,是独立的.线程在共享的内存空间中运行. 浏览器是多进程的.如下图: 并且每打开一个页面就创建了一个独立的进程.进程内有自己的多线程.如果浏览器是单进程的,那么某个页面崩了,就会影响整个浏览器. 浏览器有哪些进程: 1.Browser(浏览器):浏览器的主进…
    js同步和异步同步 前一个任务结束以后再执行下面一个任务,程序的执行顺序与任务的排列顺序是一致的 同步任务都在主线程上执行,形成一个执行线 异步 前一个任务没结束之前程序还可以执行别的任务 js的异步是通过回调函数实现的 一般情况下异步有三种类型 1.普通事件,比如click,resixe等 2.资源加载,比如load,error等 3.定时器,包括setInterval,setTimeout等 异步任务的相关回调函数添加到任务队列中 js执行机制    1.先执行栈中的同步任务    …
虽然 Vue.js 通常鼓励开发人员沿着“数据驱动”的方式思考,避免直接接触 DOM,但是有时我们确实要这么做.比如一个新闻滚动的列表项.如果在这里需要操作dom, 应该是等待 Vue 完成更新 DOM之后. 一.新闻滚动列表 1.在created函数中获取后台数据: 2.模板引擎中用v-for生成列表项: 3.调用滚动函数,假设该滚动函数式原生方法写的: 4.什么时候开始调用滚动函数比较合适呢? 二.this.$nextTick() 官方解释:将回调延迟到下次 DOM 更新循环之后执行.在修改…
    在开始讲解之前,我们先来看一段代码: console.log('1'); setTimeout(function() { console.log('2'); process.nextTick(function() { console.log('3'); }) new Promise(function(resolve) { console.log('4'); resolve(); }).then(function() { console.log('5') }) }); process.ne…