zoukankan      html  css  js  c++  java
  • 获取tranform参数函数的封装

    平时我们都会去获取元素的各种属性值,例如宽高等等的值!但是tranform是个让人很头疼的点,获取出来的是矩阵,耐何线性代数学的并不是那么6啊。

    解决方法的思路:只能采取有点取巧的方法,在我们设置的时候把它记录一下,然后在通过这个函数去获取出之前设置的transform相关的值,再也不用去依靠浏览器来知晓。

    不多说,上菜。

    <style type="text/css">
    #box {
        width: 100px;
        height: 100px;
        background: red;
    }
    </style>
    <script type="text/javascript">
    /* 设置和获取transform相关的值 */
    /*
        attr:
            rotate
            rotateX
            rotateY
            rotateZ
            scale
            scaleX
            scaleY
            skewX
            skewY
            translateX
            translateY
            translateZ    
    
        必须通过它设置,才可以通过它获取    
    */
    function setTransform(el,attr,val){
        if(!el.transform){
            el.transform = {};
            //如果元素没有这个自定义属性我们就创建一下,格式是个对象
        }
        if(typeof val == "undefined"){//如果没传val参数,说明是取值操作,则返回之前设置的对应的attr的值
            return el.transform[attr];
        } else {
            el.transform[attr] = val;//记录的值先记住或者改正
            var value = "";
            for(var s in el.transform){
                //console.log(s,el.transform[s]);
                switch(s){
                    case "rotate":
                    case "rotateX":
                    case "rotateY":
                    case "rotateZ":
                    case "skewX":
                    case "skewY":
                        value += (s+"("+el.transform[s]+"deg) ");    
                        break;
                    case "translateX":
                    case "translateY":
                    case "translateZ":    
                        value += (s+"("+el.transform[s]+"px) ");    
                        break;
                    case "scale":
                    case "scaleX":
                    case "scaleY":    
                        value += (s+"("+el.transform[s]+") ");    
                        break;        
                }
            }
            el.style.WebkitTransform = value;
            el.style.MozTransform = value;
            el.style.msTransform = value;
            el.style.transform = value;
        }
    }
    window.onload = function(){
        var box = document.querySelector('#box');
        /*
            在设置的时候去记录transform相应的值
        */
        setTransform(box,"rotate",30);
        setTransform(box,"scale",.2);
        console.log(setTransform(box,"scale"));
        
    };    
    </script>
    </head>
    <body>
    <div id="box"></div>
    </body>

    有个这样的函数,操作起来简直是方便多啦!

  • 相关阅读:
    mysql select 练习题
    mysql常用函数
    创建后表的修改:添加列+修改列+删除列+重命名表+删除整张表+删除整个数据库
    数据库里any 和 all 的区别
    mysql 高级查询
    9.12/ css3拓展、js基础语法、程序基本知识、数据类型、运算符表达方式、语句知识点
    9.11知识大纲【列表拓展】【格式与布局】
    9.10
    9.9
    9.8
  • 原文地址:https://www.cnblogs.com/hjj2ldq/p/7623056.html
Copyright © 2011-2022 走看看