全國(guó)咨詢(xún)/投訴熱線:400-618-4000

首頁(yè)技術(shù)文章正文

JavaScript開(kāi)發(fā):模塊的維護(hù)和擴(kuò)展

更新時(shí)間:2022-02-28 來(lái)源:黑馬程序員 瀏覽量:

IT培訓(xùn)班

計(jì)算器模塊通過(guò)利用函數(shù)作用域的方式,實(shí)現(xiàn)了理想的模塊化開(kāi)發(fā),如果有個(gè)需求,要在計(jì)算器案例中添加一個(gè)取余的方法,傳統(tǒng)的方式是在匿名函數(shù)中添加一個(gè)方法,且返回計(jì)算結(jié)果,示例代碼如下:

var calculator = (function () {
    //加法
    function add(x, y)  {
     return parseInt (x) + parseInt(y);
}
    //減法
    function subtract(x, y) {
     return parseInt (x) - parseInt (y);
    //乘法
    function multiply(x, y) (
     return parneInt(x) * parseInt(y);
}
    //除法
    function divide (x, y) {
     return parseInt(x) / parseInt (y);
}
    //取余
    function mod(x, y){
    return parseInt(x) % parseInt(y);
}
     return {
       add: add,
       subtract: subtract,
       multiply:multiply,
       divide: divide,
    mod: mod
   }
  })();

在上述代碼中,添加了一個(gè)取余的方法mod(),這樣的處理其實(shí)是可以實(shí)現(xiàn)當(dāng)前需求的。但是試想一下,如果這個(gè)計(jì)算模塊由第三方庫(kù)提供,難道也要修改源碼嗎?當(dāng)要對(duì)這個(gè)模塊進(jìn)行擴(kuò)展和維護(hù)的時(shí)候,或者這個(gè)模塊存有第三方依賴(lài)的時(shí)候,可以通過(guò)參數(shù)的形式將原來(lái)的模塊和第三方庫(kù)傳遞進(jìn)去。示例代碼如demol-4.html所示。

demo1-4.html:
<!DOCTYPE html>
<html>
<head>
    <meta charset="UTF-8">
    <title>模塊化開(kāi)發(fā)演變-維護(hù)和擴(kuò)展</title>
</head>
<body>
<input type="text"id="x">
<select name="" id="opt">
    <option value="0">+</option>
    <option value="1">-</option>
    <option value="2">*</option>
    <option value="3">/</option>
    <option value="4">%</option>
</select>
<input type="text" id="y">
<button id="cal">=</button>
<input type="text" id="result">
<script>
    //傳遞參數(shù)cal
    var calculator = (function(cal) {
        //加法
        function add(x, y) {
            return parseInt(x) + parseInt(y);
        }
        //減法
        function subtract(x, y) {
            return parseInt (x) - parseInt (y) ;
        }
        //乘法
        function multiply(x, y) {
            return parseInt(x) * parseInt(y);
        }
        //除法
        function divide(x, y) {
            return parseInt(x) / parseInt(y);
        }   
        cal.add = add;
        cal.subtract = subtract;
        cal.multiply = multiply;
        cal.divide = divide;
        return cal;
    })(calculator || {});

    //從代碼上來(lái)看:下面的calculator已經(jīng)把上面的calculator給覆蓋掉了
    //注意:在進(jìn)行擴(kuò)展的時(shí)候,優(yōu)先查找要擴(kuò)展的對(duì)象是否已存在
    var calculator = (function(cal) (
        //取余方法
        cal.mod = function(x, y) {
            return x % y

        }
        return cal;
    })(calculator || {});
    //獲取所有的DOM元素
    var oX = document.getElementById('x');
    var oY = document.getElementById('y');
    var oOpt = document.getElementById('opt');
    var oCal = document.getElementById('cal');
    var oResult = document.getElementById('result');
    //為等號(hào)按鈕添加單擊事件,當(dāng)按鈕被單擊時(shí)調(diào)用此方法
    oCal.addEventListener('click', function() {
        var x = oX.value.trim();
        var y = oY.value.trim();
        var opt = oOpt.value
        var result = 0;
        va1 1esult = 0;
        switch(opt) {
            case '0'
                result = calculator.add (x, Y);
                break;
            case '1':
                result = calculator.subtract (x, y);
                break;
            case '2':
                result = calculator.multiply(x, y);
                break;
            case '3':
                result = calculator.divide (x, y) ;
                break;
            case '4':
                result = calculator.mod (x, y);
                break;
                }
                oResult.value = result;
        })
</script>
</body>
</html>

在上述代碼中,第21行在用于計(jì)算的匿名函數(shù)中傳遞cal作為參數(shù),該參數(shù)可以看作匿名函數(shù)本身,第43行代碼“calculator||{}”的意思是,當(dāng)擴(kuò)展該模塊時(shí),判斷cal-culator函數(shù)是否存在,如果存在使用已經(jīng)存在的,如果不存在就重新創(chuàng)建,這樣做的好處是在加載時(shí)不需要考慮順序。第47~53行用于添加取余的方法,第80行用于調(diào)用取余方法,在瀏覽器中打開(kāi)demo1-4.html,頁(yè)面效果如圖1-3所示。

1646035195823_模塊化的演變.jpg


猜你喜歡:

HTTP模塊常用的API有哪些?

模塊化布局:使用Bootstrap執(zhí)行柵格操作

網(wǎng)頁(yè)模塊命名需要遵循哪些原則?【前端技術(shù)文章】

模塊化開(kāi)發(fā)有哪些好處?

黑馬程序員前端高級(jí)軟件工程師培訓(xùn)課程

分享到:
在線咨詢(xún) 我要報(bào)名
和我們?cè)诰€交談!