搜尋

首頁  >  問答  >  主體

css3 - 获取translateX的值

如何获取translate的值?

PHPzPHPz2866 天前854

全部回覆(4)我來回復

  • 高洛峰

    高洛峰2017-04-17 11:54:32

    你這沒寫清楚吧

    回覆
    0
  • 天蓬老师

    天蓬老师2017-04-17 11:54:32

    用正規不就行了:

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

    回覆
    0
  • 黄舟

    黄舟2017-04-17 11:54:32

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

    回覆
    0
  • ringa_lee

    ringa_lee2017-04-17 11:54:32

    試著用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...

    回覆
    0
  • 取消回覆