css3 - 获取translateX的值
PHPz
PHPz 2017-04-17 11:52:32
0
4
839

如何获取translate的值?

PHPz
PHPz

学习是最好的投资!

全部回覆(4)
小葫芦

你這沒寫清楚吧

Peter_Zhu

用正規不就行了:

'translateX(-230px)'.match(/translateX\((.*)\)/)[1]
黄舟

你這是內嵌樣式吧,外在的這樣寫出來的不是一個矩陣嗎

左手右手慢动作

試著用jquery方式取得$(el).offset().left,可以正常取得translateX的數值。

看了下jquery的offset()方法,還蠻有收穫的~

計算公式:

box.left + ( win.pageXOffset || docElem.scrollLeft ) - ( docElem.clientLeft || 0 )

box是$(el)的定位對象
( win.pageXOffset || docElem.scrollLeft )是窗體左偏移量
( docElem.clientLeft || 0 )是document左偏移量

offset()用到了好幾個之前自己完全沒印象的瀏覽器DOM自帶的屬性,ownerDocument, defaultView, pageYOffset, pageXOffset,真是TM越學越覺得自己知道得少。

關鍵函數:node.getBoundingClientRect()

這個函數巨屌無比,直接回傳一個包含DOM位置及大小的對象,
屬性包含top, bottom, left, right, height, width。
上面公式裡的box就是node.getBoundingClientRect()回傳的物件。

top, bottom, left, right四個位置屬性都是相對於文件視圖左上角計算而來。

網路上搜了一下,張鑫旭11年的時候就有篇關於這個函數的文章了。
http://www.zhangxinxu.com/wor...

熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板