V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
V2EX  ›  cyrbuzz  ›  全部回复第 13 页 / 共 31 页
回复总数  619
1 ... 9  10  11  12  13  14  15  16  17  18 ... 31  
2021-07-22 13:09:10 +08:00
回复了 Alander 创建的主题 前端开发 浏览器渲染问题疑惑
@Alander

emm,感觉我有说明= =,我简化一下:

innerHTML 并非触发渲染的条件,执行完整个循环才是,包裹你写的阻塞在内的所有代码都属于渲染前执行的任务。
2021-07-22 12:05:43 +08:00
回复了 Alander 创建的主题 前端开发 浏览器渲染问题疑惑
参考下这个: https://html.spec.whatwg.org/multipage/webappapis.html#event-loop-processing-model

说下自己的理解,里面提到第 11 步是更新渲染,11 之后还有两步,一个是执行浏览器空闲回调(requestsIdleCallback)一个是 worker 的回调。

11 步之前是执行 JS,JS 主线程就一个线程,UI 渲染会等待 JS 执行,所以你这个阻塞也阻塞了渲染,

```
const div = document.querySelector('#root')
div.innerHTML = '1'
const now = performance.now()
console.log(div.innerHTML);
```
执行到这里如果没有后续代码,浏览器会尝试执行微任务栈,然后执行 UI 渲染,此时就会渲染 1 。

但要注意 innerHTML 实时改变了 DOM,但不是触发渲染的条件,改变 DOM != 渲染,走完这个循环才是执行渲染的条件。

```
while (performance.now() - now < 100) {
console.log(now)
}
console.log(div.innerHTML);
div.innerHTML = '2'
console.log(div.innerHTML);
```

加上下面这些,只是多阻塞了主线程一会,此时走完前面的 1-10,去执行 UI 渲染,而是不断执行 console.log(now),之后执行到了:

```
div.innerHTML = '2'
console.log(div.innerHTML);
```
执行渲染时的 innerHTML 已经是 2,所以渲染出来 2 了。

一般可以用 setTimeout+Promise,这样不会阻塞 UI 渲染,只会阻塞后续代码执行:

```
function sleep(times) {
return new Promise((resolve) => {
setTimeout(() => {
resolve()
}, times)
})
}
```

```
async function draw() {
const div = document.querySelector('#root')
div.innerHTML = '1'
//const now = performance.now()
//console.log(div.innerHTML);
//while (performance.now() - now < 100) {
// console.log(now)
//}
await sleep(100)
console.log(div.innerHTML);
div.innerHTML = '2'
console.log(div.innerHTML);
}

draw()
```

相关扩展可以了解一下 Vue 的$nextTick,曾经某一个版本把它从微任务改到了宏任务,此时用$nextTick 改变 DOM 的 Style 会出现抖动(因为 宏-> 微 -> UI 渲染 -> 宏 2),本来任务应该在 UI 渲染前结果成了 UI 渲染后。
2021-07-12 09:56:54 +08:00
回复了 freedom1988 创建的主题 推广 [年中赠书] 送 3 本高级前端程序员面试笔试宝典
分子。
我的经验是....不要造假,一个谎言需要用另一个谎言来弥补。
2021-07-09 16:24:42 +08:00
回复了 cyrbuzz 创建的主题 程序员 大佬们,能帮忙指导下简历吗,快 2 年的前端~
@lin0zero

脚本小子,嘘。
https://www.v2ex.com/t/772689#reply29

之前因为这里面的内容研究了一下实现,发现有两种实现方式:

1. 通过重写 toString(或者其他只有控制台才会调用的方法),console.log 不打开控制台不会 console.log ,console.log 一个函数(或者其他什么东西)的时候会调用 toString 方法,重写这个 toString 即可判断是否打开了 F12 。

2. 记录时间戳,之后写一个 debugger,在记录一个时间戳,两个时间戳相减,debugger 会造成第二个时间戳记录时间远大于预期(比如 50ms),这时就可以判断打开了 F12 。
2021-07-02 18:47:34 +08:00
回复了 cyrbuzz 创建的主题 程序员 大佬们,能帮忙指导下简历吗,快 2 年的前端~
@JayFang1993
@thulof
@lzuntalented

大佬们,已撩(☆▽☆)。
2021-07-02 18:45:21 +08:00
回复了 cyrbuzz 创建的主题 程序员 大佬们,能帮忙指导下简历吗,快 2 年的前端~
@LiubaiQ
= =...遁地我也开过(悄悄说)。
2021-07-02 18:44:34 +08:00
回复了 cyrbuzz 创建的主题 程序员 大佬们,能帮忙指导下简历吗,快 2 年的前端~
@NitroS
(☆▽☆)
2021-07-02 13:13:37 +08:00
回复了 cyrbuzz 创建的主题 程序员 大佬们,能帮忙指导下简历吗,快 2 年的前端~
@Lemeng

哎嘿= =....
2021-07-02 13:13:15 +08:00
回复了 cyrbuzz 创建的主题 程序员 大佬们,能帮忙指导下简历吗,快 2 年的前端~
@chenquincy

蹭大佬好友位~。
2021-07-02 13:11:43 +08:00
回复了 cyrbuzz 创建的主题 程序员 大佬们,能帮忙指导下简历吗,快 2 年的前端~
@AmberJiang

开心~,又被一个大佬肯定。
2021-07-02 13:10:39 +08:00
回复了 cyrbuzz 创建的主题 程序员 大佬们,能帮忙指导下简历吗,快 2 年的前端~
@fgk

谢谢~,还没想好。
2021-07-02 13:10:08 +08:00
回复了 cyrbuzz 创建的主题 程序员 大佬们,能帮忙指导下简历吗,快 2 年的前端~
@yanzhiling2001

你暴露了,土豆地雷,我是不会上当的。
2021-07-02 09:39:52 +08:00
回复了 cyrbuzz 创建的主题 程序员 大佬们,能帮忙指导下简历吗,快 2 年的前端~
@919615766 加你了大佬。
2021-07-02 09:38:50 +08:00
回复了 cyrbuzz 创建的主题 程序员 大佬们,能帮忙指导下简历吗,快 2 年的前端~
@Jooooooooo

嘿嘿,信心+1~,谢谢大佬。
2021-07-02 09:37:53 +08:00
回复了 cyrbuzz 创建的主题 程序员 大佬们,能帮忙指导下简历吗,快 2 年的前端~
@hjue

原来如此~感谢。
2021-07-01 18:44:52 +08:00
回复了 cyrbuzz 创建的主题 程序员 大佬们,能帮忙指导下简历吗,快 2 年的前端~
@919615766

嗯嗯,CSS 所见即所得嘛...不会的 copy hhhh 。
2021-07-01 18:36:00 +08:00
回复了 cyrbuzz 创建的主题 程序员 大佬们,能帮忙指导下简历吗,快 2 年的前端~
@yaozeyuan93

哎= =,确实每次都没信心,有大佬们的肯定就信心百倍了!已发送请求大佬,蹭个大佬好友位~。
1 ... 9  10  11  12  13  14  15  16  17  18 ... 31  
关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   2859 人在线   最高记录 6679   ·     Select Language
创意工作者们的社区
World is powered by solitude
VERSION: 3.9.8.5 · 24ms · UTC 08:37 · PVG 16:37 · LAX 00:37 · JFK 03:37
Developed with CodeLauncher
♥ Do have faith in what you're doing.