js拖拽插件通過改變position或translate做位移风响,性能對(duì)比

性能差距還是很大的特別是在移動(dòng)設(shè)備上镰禾,因?yàn)榇蠹叶贾罏g覽器在處理這兩種樣式時(shí)的流水線不同。position更新進(jìn)行 layout 重計(jì)算顾腊。而translate只需要對(duì)本元素的幾何數(shù)據(jù)點(diǎn)做偏移就好了粤铭。不過性能最優(yōu)的方式還是要為被拖拽的那個(gè)元素觸發(fā)composite layer(可以叫它合成層),因?yàn)楝F(xiàn)在瀏覽器一般都是 合成化渲染杂靶,并且大部分 光柵化(就是把元素形狀的幾何數(shù)據(jù)描述變成像素描述的過程梆惯,可以理解成矢量變成位圖)過程都是在CPU上進(jìn)行的酱鸭,如果不把被拖拽的那個(gè)元素觸發(fā)成為 合成層 那么CPU就會(huì)重復(fù)的paint這個(gè)元素,這是不合理的(CPU paint的過程比較耗時(shí))垛吗,所以應(yīng)該讓CPU盡量少的paint這個(gè)元素凹髓,最好只paint一次,之后的拖拽(也就是位移怯屉,甚至是旋轉(zhuǎn)啊扁誓、縮放啊等這些仿射變換) 都可以直接交給GPU在合成(composited)的時(shí)候來做,這也就是所謂的硬件加速機(jī)制蚀之。合成過程就是把幾個(gè)合成層(一個(gè)合成層可以是 一個(gè)元素或多個(gè)元素組合經(jīng)過CPU 光柵化后得到的圖片)根據(jù)各個(gè)層的幾何頂點(diǎn)信息蝗敢、矩陣描述、透明度足删、blend效果等信息使用GPU進(jìn)行重新的光柵化渲染到一張直接投影到屏幕上的圖片上(幀緩沖區(qū) framebuffer)寿谴,然而這里的光柵化是非常快的失受,不同于CPU的那個(gè)光柵化的過程讶泰。原因大致如下:一、因?yàn)檫@個(gè)時(shí)候的渲染只是把一張現(xiàn)成的位圖合成到一起(就像紋理貼圖拂到,可以簡(jiǎn)單理解成像素值的簡(jiǎn)單計(jì)算和拷貝)痪署。而不像CPU光柵化,它是將非常復(fù)雜的幾何數(shù)據(jù)(是由瀏覽器分析dom的css樣式所得到的)通過一系列復(fù)雜的邏輯計(jì)算后得到一個(gè)像素最后得到一張圖片兄旬。二狼犯、因?yàn)镚PU有非常多個(gè)處理單元在并行的處理這些簡(jiǎn)單的渲染,它的計(jì)算吞吐量是很大的领铐。而CPU的處理單元非常少悯森,做強(qiáng)邏輯的計(jì)算非常適合,但是做這種簡(jiǎn)單的加減乘除計(jì)算不如GPU快

性能差距還是很大的特別是在移動(dòng)設(shè)備上绪撵,因?yàn)榇蠹叶贾罏g覽器在處理這兩種樣式時(shí)的流水線不同瓢姻。position更新進(jìn)行 layout 重計(jì)算。而translate只需要對(duì)本元素的幾何數(shù)據(jù)點(diǎn)做偏移就好了音诈。不過性能最優(yōu)的方式還是要為被拖拽的那個(gè)元素觸發(fā)composite layer(可以叫它合成層)幻碱,因?yàn)楝F(xiàn)在瀏覽器一般都是 合成化渲染,并且大部分 光柵化(就是把元素形狀的幾何數(shù)據(jù)描述變成像素描述的過程细溅,可以理解成矢量變成位圖)過程都是在CPU上進(jìn)行的褥傍,如果不把被拖拽的那個(gè)元素觸發(fā)成為 合成層 那么CPU就會(huì)重復(fù)的paint這個(gè)元素,這是不合理的(CPU paint的過程比較耗時(shí))谒兄,所以應(yīng)該讓CPU盡量少的paint這個(gè)元素摔桦,最好只paint一次社付,之后的拖拽(也就是位移承疲,甚至是旋轉(zhuǎn)啊邻耕、縮放啊等這些仿射變換) 都可以直接交給GPU在合成(composited)的時(shí)候來做,這也就是所謂的硬件加速機(jī)制燕鸽。合成過程就是把幾個(gè)合成層(一個(gè)合成層可以是 一個(gè)元素或多個(gè)元素組合經(jīng)過CPU 光柵化后得到的圖片)根據(jù)各個(gè)層的幾何頂點(diǎn)信息兄世、矩陣描述、透明度啊研、blend效果等信息使用GPU進(jìn)行重新的光柵化渲染到一張直接投影到屏幕上的圖片上(幀緩沖區(qū) framebuffer)御滩,然而這里的光柵化是非常快的党远,不同于CPU的那個(gè)光柵化的過程削解。原因大致如下:一、因?yàn)檫@個(gè)時(shí)候的渲染只是把一張現(xiàn)成的位圖合成到一起(就像紋理貼圖沟娱,可以簡(jiǎn)單理解成像素值的簡(jiǎn)單計(jì)算和拷貝)氛驮。而不像CPU光柵化,它是將非常復(fù)雜的幾何數(shù)據(jù)(是由瀏覽器分析dom的css樣式所得到的)通過一系列復(fù)雜的邏輯計(jì)算后得到一個(gè)像素最后得到一張圖片济似。二矫废、因?yàn)镚PU有非常多個(gè)處理單元在并行的處理這些簡(jiǎn)單的渲染,它的計(jì)算吞吐量是很大的砰蠢。而CPU的處理單元非常少蓖扑,做強(qiáng)邏輯的計(jì)算非常適合,但是做這種簡(jiǎn)單的加減乘除計(jì)算不如GPU快

優(yōu)秀文章

translate 是 transform 屬性的?個(gè)值台舱。改變transform或opacity不會(huì)觸發(fā)瀏覽器重新布局(reflow)或重繪(repaint)律杠,只會(huì)觸發(fā)復(fù)合(compositions)。?改變絕對(duì)定位會(huì)觸發(fā)重新布局竞惋,進(jìn)?觸發(fā)重繪和復(fù)合俩功。transform使瀏覽器為元素創(chuàng)建?個(gè) GPU 圖層,但改變絕對(duì)定位會(huì)使?到 CPU碰声。 因此translate()更?效诡蜓,可以縮短平滑動(dòng)畫的繪制時(shí)間。 ?translate改變位置時(shí)胰挑,元素依然會(huì)占據(jù)其原始空間蔓罚,絕對(duì)定位就不會(huì)發(fā)?這種情況。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末瞻颂,一起剝皮案震驚了整個(gè)濱河市豺谈,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌贡这,老刑警劉巖茬末,帶你破解...
    沈念sama閱讀 207,113評(píng)論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡丽惭,警方通過查閱死者的電腦和手機(jī)击奶,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,644評(píng)論 2 381
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來责掏,“玉大人柜砾,你說我怎么就攤上這事』怀模” “怎么了痰驱?”我有些...
    開封第一講書人閱讀 153,340評(píng)論 0 344
  • 文/不壞的土叔 我叫張陵担映,是天一觀的道長(zhǎng)另萤。 經(jīng)常有香客問我,道長(zhǎng)四敞,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 55,449評(píng)論 1 279
  • 正文 為了忘掉前任忿危,我火速辦了婚禮铺厨,結(jié)果婚禮上硬纤,老公的妹妹穿的比我還像新娘。我一直安慰自己筝家,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 64,445評(píng)論 5 374
  • 文/花漫 我一把揭開白布腮鞍。 她就那樣靜靜地躺著移国,像睡著了一般道伟。 火紅的嫁衣襯著肌膚如雪迹缀。 梳的紋絲不亂的頭發(fā)上祝懂,一...
    開封第一講書人閱讀 49,166評(píng)論 1 284
  • 那天拟淮,我揣著相機(jī)與錄音兴泥,去河邊找鬼脂倦。 笑死弄抬,一個(gè)胖子當(dāng)著我的面吹牛缕允,可吹牛的內(nèi)容都是我干的蹭越。 我是一名探鬼主播,決...
    沈念sama閱讀 38,442評(píng)論 3 401
  • 文/蒼蘭香墨 我猛地睜開眼驾霜,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼买置!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起蓉冈,我...
    開封第一講書人閱讀 37,105評(píng)論 0 261
  • 序言:老撾萬榮一對(duì)情侶失蹤寞酿,失蹤者是張志新(化名)和其女友劉穎脱柱,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體榨为,經(jīng)...
    沈念sama閱讀 43,601評(píng)論 1 300
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡柠逞,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,066評(píng)論 2 325
  • 正文 我和宋清朗相戀三年板壮,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 38,161評(píng)論 1 334
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡透葛,死狀恐怖卿樱,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情萨蚕,我是刑警寧澤蹄胰,帶...
    沈念sama閱讀 33,792評(píng)論 4 323
  • 正文 年R本政府宣布,位于F島的核電站裕寨,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏捻艳。R本人自食惡果不足惜庆猫,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,351評(píng)論 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望阅悍。 院中可真熱鬧,春花似錦节视、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,352評(píng)論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至兔魂,卻和暖如春举娩,著一層夾襖步出監(jiān)牢的瞬間构罗,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 31,584評(píng)論 1 261
  • 我被黑心中介騙來泰國(guó)打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留吊奢,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 45,618評(píng)論 2 355
  • 正文 我出身青樓召边,卻偏偏與公主長(zhǎng)得像逻谦,于是被迫代替她去往敵國(guó)和親陪蜻。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 42,916評(píng)論 2 344

推薦閱讀更多精彩內(nèi)容