una_chou
unaJ
2017-09-12 01:12

javascript的函数封装

  • javascript

代码如下:

function rotatePlusLink() {
            $(".linkDiv").each(function () {

                var tr = window.getComputedStyle($(this)[0], null).getPropertyValue("transform");

                if (tr == 'none') {
                    this.css('transform', 'scale(1) rotate(0deg)');
                    return;
                }

                var values = tr.split('(')[1].split(')')[0].split(',');
                var a = values[0];
                var b = values[1];
                var c = values[2];
                var d = values[3];

                var scale = Math.sqrt(a * a + b * b);

                var sin = b / scale;
                var angle = Math.round(Math.atan2(b, a) * (180 / Math.PI));

                this.style.transform = 'rotate(' + (angle + 5) + 'deg) scale(' + scale + ')';
            });
}


function rotateReduLink() {
            $(".linkDiv").each(function () {

                var tr = window.getComputedStyle($(this)[0], null).getPropertyValue("transform");

                if (tr == 'none') {
                    this.css('transform', 'scale(1) rotate(0deg)');
                    return;
                }

                var values = tr.split('(')[1].split(')')[0].split(',');
                var a = values[0];
                var b = values[1];
                var c = values[2];
                var d = values[3];

                var scale = Math.sqrt(a * a + b * b);

                var sin = b / scale;
                var angle = Math.round(Math.atan2(b, a) * (180 / Math.PI));

                this.style.transform = 'rotate(' + (angle - 5) + 'deg) scale(' + scale + ')';
            });
}

这两个函数中的linkDiv的设置 怎么能封装成一个函数调用啊? 这两个函数只有一个地方不一样 就是设置属性的那里,一个加号,一个减号。

  • 点赞
  • 回答
  • 收藏
  • 复制链接分享

3条回答