unaJ 2017-09-12 01:12 采纳率: 15.4%
浏览 1331
已采纳

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条回答 默认 最新

  • Tsui丶 2017-09-12 01:25
    关注

    看你的写法这两个函数应该是绑定在相应的标签上的这样的话你将这个操作符(+/-)作为一个参数直接传进来不就行了

    function rotateLink(str){
    ....
    if(("+").equals(str)){
    this.style.transform = 'rotate(' + (angle + 5) + 'deg) scale(' + scale + ')';
    }
    if(("-").equals(str)){
    this.style.transform = 'rotate(' + (angle - 5) + 'deg) scale(' + scale + ')';
    }
    ...............
    }

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(2条)

报告相同问题?

悬赏问题

  • ¥100 c语言,请帮蒟蒻写一个题的范例作参考
  • ¥15 名为“Product”的列已属于此 DataTable
  • ¥15 安卓adb backup备份应用数据失败
  • ¥15 eclipse运行项目时遇到的问题
  • ¥15 关于#c##的问题:最近需要用CAT工具Trados进行一些开发
  • ¥15 南大pa1 小游戏没有界面,并且报了如下错误,尝试过换显卡驱动,但是好像不行
  • ¥15 没有证书,nginx怎么反向代理到只能接受https的公网网站
  • ¥50 成都蓉城足球俱乐部小程序抢票
  • ¥15 yolov7训练自己的数据集
  • ¥15 esp8266与51单片机连接问题(标签-单片机|关键词-串口)(相关搜索:51单片机|单片机|测试代码)