javascript - translate3d 的 css3 替代品?

标签 javascript css

我正在尝试转换为 ipad 等支持触摸的设备制作的 JS 脚本,以便它可以与鼠标手势一起使用。

该脚本使用 translate3d,(我认为)它是特定于 webkit 的,但我想让它在尽可能多的浏览器中工作。那么,translate3d 的 CSS3 替代品是什么?

这是它在 JavaScript 中的使用方式:

element.style.webkitTransform = 'translate3d(500px, 0, 0)';

我对 CSS3 的了解非常有限,因此非常感谢您提供任何示例/解释。

最佳答案

Translate3d 是 CSS3,大多数浏览器还没有实现它(Chrome/Safari 是唯一通过 Webkit 支持它的主要浏览器)。它是一种 3-D 转换样式。

还有切出 Z 轴的二维变换,所以:

translate3d(X,Y,Z); // or translateX(X), translateY(Y), translateZ(Z);

成为

translate(X,Y);

值得庆幸的是,所有主流浏览器(IE9 及更高版本)大多支持二维变换,但它们需要浏览器前缀。在您的示例中,这看起来像:

/* CSS */    
selector {
    transform: translate(500px, 0);
    -o-transform: translate(500px, 0);         /* Opera */
    -ms-transform: translate(500px, 0);        /* IE 9 */
    -moz-transform: translate(500px, 0);       /* Firefox */
    -webkit-transform: translate(500px, 0);    /* Safari and Chrome */
}

/* JS */
element.style.transform = 'translate(500px, 0)';
element.style.OTransform = 'translate(500px, 0)';          // Opera
element.style.msTransform = 'translate(500px, 0)';         // IE 9
element.style.MozTransform = 'translate(500px, 0)';        // Firefox
element.style.WebkitTransform = 'translate(500px, 0)';     // Safari and Chrome

有关 2-D 和 3-D 变换的更多信息,请参阅:
http://www.w3.org/TR/css3-2d-transforms/
http://www.w3.org/TR/css3-3d-transforms/

2-D 变换的一个缺点是,与 3-D 变换不同,它们不是 GPU 加速的。有关硬件加速对过渡和动画有多大帮助的重要信息,请参阅此链接:http://ariya.blogspot.com/2011/07/fluid-animation-with-accelerated.html .

为了更好地跨浏览器,您可以编写一个函数来找到要应用的正确浏览器转换样式(或确定浏览器不支持转换),如下所示:

var getTransformProperty = function(node) {
    var properties = [
        'transform',
        'WebkitTransform',
        'msTransform',
        'MozTransform',
        'OTransform'
    ];
    var p;
    while (p = properties.shift()) {
        if (typeof node.style[p] != 'undefined') {
            return p;
        }
    }
    return false;
};

您还可以使用功能检测库,例如 Modernizr .

关于javascript - translate3d 的 css3 替代品?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/8143953/

相关文章:

javascript - jQuery slideUp/Down 淡入/淡出不对称

php - 使用 Greasemonkey 和 PHP 下载和上传

javascript - 重新加载页面时如何隐藏vue js代码?

html - 当我编辑输入元素的大小时,为什么相邻元素的大小也会增加?

html - 使用 CSS 将图像悬停在反向

html - 为什么带有 clearfix 的 inline-flex 元素有一个奇怪的空白?

javascript - 我怎样才能让边框无限期地切换颜色?

javascript - 是否有可能确定正在运行的浏览器是否是 JavaScript 中的默认浏览器?

javascript - 如何使用 "eval"将多个变量传递到 "with"表达式中?

html - html表格中相对定位a