亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

關于opacity觸發paint的問題

關于opacity觸發paint的問題

慕的地8271018 2019-02-05 19:53:36
<!DOCTYPE html><html lang="en"><head>     <meta charset="UTF-8">     <meta name="viewport" content="width=device-width, initial-scale=1.0">     <meta http-equiv="X-UA-Compatible" content="ie=edge">     <title>Document</title>     <style>         #react {            position: relative;            width: 100px;            height: 100px;            background-color: red;            opacity: 1;            transform: translateZ(0)         }    </style></head><body>     <div id="react"></div>     <script type="text/javascript">         setTimeout(() => {            document.getElementById("react").style.opacity = "0"         }, 2000);    </script></body></html>已經用translteZ提升為合成層,改變opacity仍然出觸發paint這是為什么,和認知好像有點不符
查看完整描述

1 回答

?
HUH函數

TA貢獻1836條經驗 獲得超4個贊

透明度值的變化是不會引發 paint 的,但是從 opacity: 1; 到 opacity: 0; 不是數值變化那么簡單,是有透明和沒有透明的關系,這個差距可是很大的。你想想一下,假設頁面沒有 1 行 js 代碼, 則 js 解析,執行這個過程完全不會發生,我們可以做優化,直接連 js 引擎都不加載。所有,從無到有和從 1到100之間的差距可不單單是數值的變化那么簡單。

如果你一開始將 opacity 的初始值設為 0.9,然后在通過 js 改為 0,此時你就會發現 paint 事件消失了。


查看完整回答
反對 回復 2019-02-05
  • 1 回答
  • 0 關注
  • 1157 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號