成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

寫一個方便維護的 jquery 代碼

shmily / 3106人閱讀

摘要:前言最近碰到這樣一個項目,業(yè)務邏輯全部都搬到前端,后端只提供。渲染數(shù)據(jù),用最原始的方法對代碼拼接。拼接好數(shù)據(jù)之后再一口氣進事先在方法緩存好的對象里。最后這樣子的寫法我覺得還是比較方便維護的。

前言

最近碰到這樣一個項目,業(yè)務邏輯全部都搬到前端,后端只提供API。
但是是在已有的項目上面做這樣做,也就是在已有的項目上添加模塊,這個模塊采用前后端分工的方式來做。
因為各種原因,所以只有 jquery 可以用一下,萬惡的ie。

jquery代碼示例

先上代碼,如果要運行,需要額外導入mock.js。
js

$(function() {
    var list = {
        init: function() {
            // 初始化
            this.$list = $("#list");
            this.render();
        },
        render: function() {
            // 渲染
            this.getData();
            this.bind();
        },
        renderData: function(data) {
            // 渲染數(shù)據(jù)
            var temp = {
                listTemp: ""
            }
            $.each(data, function(i, iObj) {
                temp.listTemp += 
                    ""+
                        "" + iObj.name + ""+
                        "" + iObj.price + ""+
                        "" + 
                            ""+
                            "" + iObj.color + ""+
                        ""+
                        "" + iObj.name + ""+
                    "";
            });
            
            this.$list.html(temp.listTemp);
        },
        bind: function() {
            // 綁定事件
            var self = $(this);
            this.$list.on("click", "tr", function() {
                alert($(this).data("id"));
            });
        },
        getData: function() {
            // 獲取數(shù)據(jù)
            var self = this;
            Mock.mock("http://data.cn", {
                "list|1-20": [
                    {
                    "id|+1": 1,
                    "name": "@name",
                    "price|1-1000": 1000,
                    "color": "@color",
                    "remark": "@remark"
                    }
                ]
            });
            $.ajax({
                type: "get",
                url: "http://data.cn",
                success: function(data) {
                    self.renderData($.parseJSON(data).list);
                }
            });
        }
    }
    list.init();
});

html



    
        
        
        
    
    
        
名稱 價格 顏色 備注

css

body {
  margin: 0;
  font-family: "微軟雅黑";
}
.table {
  width: 80%;
  margin: 20px auto;
  border-collapse: collapse;
  border-spacing: 0;
}
.table td,
.table th {
  text-indent: 2%;
  text-align: left;
}
.table thead tr {
  height: 40px;
}
.table .body {
  height: 400px;
  overflow: auto;
  display: block;
}
.table tbody tr {
  height: 40px;
  cursor: pointer;
}
.table tbody tr:nth-child(2n + 1) {
  background-color: #eafff4;
}
.table tbody tr:nth-child(2n) {
  background-color: #fff;
}
.table tbody tr:hover {
  background-color: #b0e5ff;
}
.table tbody tr span {
  vertical-align: middle;
}
.table tbody tr .color-simple {
  width: 20px;
  height: 20px;
  margin-right: 10px;
  border-radius: 2px;
  display: inline-block;
}
解析

這是一個簡單的例子,首先 js 內部執(zhí)行順序是這樣的:

init(初始化)

render(渲染頁面)

bind(綁定事件)getData(加載數(shù)據(jù))

renderData(渲染數(shù)據(jù))

init

初始化,加載一個模塊的開始。

主要用來緩存一些成員變量,如果是 jquery對象的 話就在之前加個 "$",這樣做是為了跟普通元素區(qū)別開來。

render

渲染頁面,顧名思義,就是渲染頁面的函數(shù)。

在這個函數(shù)內部調用了 getData() 和 bind() 兩個方法,getData()是為了去取數(shù)據(jù),但為什么要在這里調用 bind() 方法呢,難道不應該在渲染完數(shù)據(jù)之后再綁定事件呢,說到 bind() 的時候再說為什么。

如果有另外的子模塊需要渲染的話,也可以放在這里加載。 (比如在 list 模塊下面有個 editPrice子模塊,是一個多帶帶的模塊,就可以并列著寫,然后在這里調用。)

$(function() {
    // 我是父模塊
    var list = {
        init: function() {
            // 初始化
            this.$list = $("#list");
            this.render();
        },
        render: function() {
            // 渲染
            this.getData();
            // 我調用了子模塊
            editPrice.init();
            this.bind();
        },
        renderData: function() {},
        bind: function() {},
        getData: function() {}
    }

    // 我是子模塊
    var editPrice = {
        init: function() {},
        render: function() {},
        renderData: function() {},
        bind: function() {},
        getData: function() {}
    }
    list.init();
});

bind:

綁定事件,所有的綁定事件全部都在這里處理。

這里定義了一個 “self” 變量,這是因為再綁定事件的 on 的函數(shù)內部由于作用域不同,所以調用不了其它 list 對象的成員變量和方法,所以事先緩存了起來,有的人會叫 _this、me、that 這些名字,我的習慣是叫 self。

關于上一點其實還可以再函數(shù)尾部加上 bind() 方法綁定作用域的,這樣就不需要額外申明一個變量了,沒有用是因為我不大習慣。。。

這里講一下為什么 bind() 方法要放在 render() 里面,之所以不 renderData() 之后做是因為數(shù)據(jù)可能會重復調用,比如分頁,就可能會重復調用 renderData() 這個方法,所以才利用了事件委托的辦法。

getData:

獲取數(shù)據(jù),就是在這里用 ajax 和后端進行通信。

用 Mock.js 去模擬一個后端Api,如果你還不知道這個東西,點這里。

這里的 self 跟 bind() 里的 self 同理,為了調用成員方法 renderData()。

renderData:

渲染數(shù)據(jù),用最原始的方法對代碼拼接HTML。

拼接數(shù)據(jù)的時候,前后用單引號的話,就可以不用擔心會跟里面 class 或者其它屬性的雙引號起沖突了。

拼接好數(shù)據(jù)之后再一口氣 html 進事先在 init() 方法緩存好的 jquery對象 里。

另外: 如果我的模塊要在其它的 js 的里調用怎么辦,我的做法是 把數(shù)據(jù)綁定到 window 對象上。

$(function() {
    var list = {}
    list.init();
    window.list = list;
});
最后

這樣子的寫法我覺得還是比較方便維護的。

如果有什么想跟我討論的話,請私信。

文章版權歸作者所有,未經(jīng)允許請勿轉載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉載請注明本文地址:http://systransis.cn/yun/80887.html

相關文章

  • 一個方便維護 jquery 代碼

    摘要:前言最近碰到這樣一個項目,業(yè)務邏輯全部都搬到前端,后端只提供。渲染數(shù)據(jù),用最原始的方法對代碼拼接。拼接好數(shù)據(jù)之后再一口氣進事先在方法緩存好的對象里。最后這樣子的寫法我覺得還是比較方便維護的。 前言 最近碰到這樣一個項目,業(yè)務邏輯全部都搬到前端,后端只提供API。但是是在已有的項目上面做這樣做,也就是在已有的項目上添加模塊,這個模塊采用前后端分工的方式來做。因為各種原因,所以只有 jqu...

    madthumb 評論0 收藏0
  • 一個方便維護 jquery 代碼

    摘要:前言最近碰到這樣一個項目,業(yè)務邏輯全部都搬到前端,后端只提供。渲染數(shù)據(jù),用最原始的方法對代碼拼接。拼接好數(shù)據(jù)之后再一口氣進事先在方法緩存好的對象里。最后這樣子的寫法我覺得還是比較方便維護的。 前言 最近碰到這樣一個項目,業(yè)務邏輯全部都搬到前端,后端只提供API。但是是在已有的項目上面做這樣做,也就是在已有的項目上添加模塊,這個模塊采用前后端分工的方式來做。因為各種原因,所以只有 jqu...

    王笑朝 評論0 收藏0
  • [轉載]jQuery插件開發(fā)詳細教程

    摘要:本教程可能不是最精品的,但一定是最細致的。插件開發(fā)下面我們就來看第二種方式的插件開發(fā)。然后我們的插件代碼在這個方法里面展開。 要說jQuery 最成功的地方,我認為是它的可擴展性吸引了眾多開發(fā)者為其開發(fā)插件,從而建立起了一個生態(tài)系統(tǒng)。這好比大公司們爭相做平臺一樣,得平臺者得天下。蘋果,微軟,谷歌等巨頭,都有各自的平臺及生態(tài)圈。 學會使用jQuery并不難,因為它簡單易學,并且相信你接觸...

    kevin 評論0 收藏0
  • 作為一名前端開發(fā)工程師,你必須掌握WEB模板引擎:Handlebars

    摘要:簡單來說,模板最本質的作用是變靜為動,一切利于這方面的都是優(yōu)勢,不利于的都是劣勢。二選擇的原因全球最受歡迎的模板引擎是全球使用率最高的模板引擎,所以當之無愧是全球最受歡迎的模板引擎。創(chuàng)建更為復雜一些,當時功能更加強大。 showImg(https://segmentfault.com/img/bVbb3kg?w=775&h=216); 為什么需要使用模板引擎? 關于為什么要使用模板引擎...

    yuanzhanghu 評論0 收藏0
  • jQuery 源碼系列(九)回溯機制

    摘要:在對象的內部,有著一個對象棧,用來維護所有已經(jīng)操作過的對象。這樣來想一想,如果每一個對象都有一個指針指向上一個對象的話,也就間接組成了一個對象棧。 歡迎來我的專欄查看系列文章。 學習了 prevObject 之后發(fā)現(xiàn),我之前寫的一篇博客介紹 pushStack 函數(shù)那個內容是有問題的。本來我以為這個 pushStack 函數(shù)就是一個普通的函數(shù),它接受一個 DOM (數(shù)組)參數(shù),把該參數(shù)...

    hss01248 評論0 收藏0

發(fā)表評論

0條評論

最新活動
閱讀需要支付1元查看
<