JS控制CSS3,添加浏览器兼容前缀

时间:2022-02-20 03:49:04

不同浏览器对于有些css3属性名字定义的时候,会带上特有的前缀,所以在css编写的时候,经常会一个属性写多个不同的前缀进行兼容。比如:

div
{
transform: rotate(30deg);
-ms-transform: rotate(30deg);        /* IE 9 */
-webkit-transform: rotate(30deg);    /* Safari and Chrome */
-o-transform: rotate(30deg);        /* Opera */
-moz-transform: rotate(30deg);        /* Firefox */
}

有时候,我们需要通过js动态控制css3属性,这时候就需要根据不同的浏览器添加不同的前缀。当然,我们也可以将所有的前缀全部设置,就像以下这种方式:

<!DOCTYPE html>
<html>
  <head>
    <meta charset="utf-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0, user-scalable=0, minimum-scale=1.0, maximum-scale=1.0">
    <title>JS控制CSS3,添加浏览器兼容前缀</title>
  </head>
  <body>
       <div id="target" style="background: blue">
      测试
   </div>
  </body>
  <script type="text/javascript">
    var target = document.getElementById("target"); 
    target.style.MozTransform = 'rotate(30deg)';
    target.style.OTransform = 'rotate(30deg)';
    target.style.msTransform = 'rotate(30deg)';
    target.style.transform = 'rotate(30deg)';
    target.style.webkitTransform = 'rotate(30deg)';
  
  </script>
</html>

 

这种方式能够设置属性成功,但是看起来就不是很优雅。代码冗余,而且设置了很多无效的属性。这里可以通过以下的方式,给不同的浏览器加上合适的前缀。

<!DOCTYPE html>
<html>
  <head>
    <meta charset="utf-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0, user-scalable=0, minimum-scale=1.0, maximum-scale=1.0">
    <title>JS控制CSS3,添加浏览器兼容前缀</title>
  </head>
  <body>
    <div id="target" style="background: blue">
      测试
    </div>
  </body>
  <script type="text/javascript">
  var elementStyle = document.createElement('div').style;
  var vendor = (function(){
  var transformNames = {
      webkit: 'webkitTransform',
      Moz: 'MozTransform',
      O: 'OTransform',
      ms: 'msTransform',
      standard: 'transform'
    };

    for (var key in transformNames) {
      if (elementStyle[transformNames[key]] !== undefined) {
        return key;
      }
    }

    return false;
  })();

  function prefixStyle(style) {
    if (vendor === false) {
      return false;
    }

    if (vendor === 'standard') {
      return style;
    }

    return vendor + style.charAt(0).toUpperCase() + style.substr(1);
  }
  target.style[prefixStyle('transform')] = 'rotate(30deg)'
  </script>
</html>

采用类似于能力检测的方式,找到对应浏览器内核支持的前缀。然后按照规则修改属性,添加前缀。