通过正则获取transform偏移的数值

42次阅读

共计 960 个字符,预计需要花费 3 分钟才能阅读完成。

offsetWidth 获取元素宽
offsetLeft 获取元素定位偏移值
当元素使用 CSS3 中的 transform(translateX:100px)偏移时,无法用 offsetLeft 获取偏移值
解决办法:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
    <style>
        .box{
            width: 200px;
            height: 200px;
            background-color: red;
        }
    </style>
</head>
<body>
<div class="box">
</div>
<button class="btn"> 按钮 </button>
<button class="btn2"> 按钮 2 </button>
<script>
    var box = document.querySelector(".box");
    var boxwidth = box.offsetWidth;
    console.log(boxwidth); // 盒子的宽度 200
    var btn = document.querySelector(".btn");
    var btn2 = document.querySelector(".btn2");
    // 点击按钮让盒子移动 负值表示左移 移动的量为 100
    btn.onclick = function () {box.style.transform = "translateX(-100px)";
        box.style.webkitTransform = "translateX(-100px)";
    };
    // 点击按钮 2 打印出移动的值
    btn2.onclick = function () {console.log(box.offsetLeft); // 默认的偏移量 8
        var x = box.style.transform || box.style.webkitTransform;
        console.log(x); // translateX(-100px)
        var reg = /(translateX\(-)(\d+)(px\))/; // 左移和右移的正则相差一个 - 
        var result = reg.exec(x)[2]; 
        console.log(result); // 通过正则获取到移动的值 100
    }
</script>
</body>
</html>

正文完
 0