第七色在线视频,2021少妇久久久久久久久久,亚洲欧洲精品成人久久av18,亚洲国产精品特色大片观看完整版,孙宇晨将参加特朗普的晚宴

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

javascript的函數(shù)封裝

javascript的函數(shù)封裝

炎炎設計 2019-05-03 18:15:58
代碼如下: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 + ')';             }); }這兩個函數(shù)中的linkDiv的設置 怎么能封裝成一個函數(shù)調用啊? 這兩個函數(shù)只有一個地方不一樣 就是設置屬性的那里,一個加號,一個減號。
查看完整描述

4 回答

?
HUH函數(shù)

TA貢獻1836條經(jīng)驗 獲得超4個贊

//ES6 函數(shù)的解構賦值,賦初值5
function rotateLink(nums = 5) {
$(".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 + nums) + 'deg) scale(' + scale + ')';
        });

}
不推薦使用eval


查看完整回答
反對 回復 2019-05-13
?
慕俠2389804

TA貢獻1719條經(jīng)驗 獲得超6個贊

你可以另寫一個函數(shù)去接受你的angle和scale值,然后再調用此方法,或者直接寫到這個方法中來。對于equals,抱歉 忘了js中不用這個了 直接用==就好了

查看完整回答
反對 回復 2019-05-13
?
智慧大石

TA貢獻1946條經(jīng)驗 獲得超3個贊

兩個辦法,一個加一個參數(shù),這一行用if判斷
一個是直接傳入+ - 作為字符串,程序中用eval求值

查看完整回答
反對 回復 2019-05-13
  • 4 回答
  • 0 關注
  • 638 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯(lián)系客服咨詢優(yōu)惠詳情

幫助反饋 APP下載

慕課網(wǎng)APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網(wǎng)微信公眾號