前端解耦的一个最简单示例

 

且看这样一段HTML片段:

 

<div id="name" style="background-color:red" οnclick="alert('');">Jim</div>

 

这是前端代码全部耦合在一起的例子,下面对它进行MVC解耦。

 

第一步解耦,把View层分离出来:

 

<div id="name" class="name" οnclick="alert('');">Jim</div>

 

同时,引入一表示name的css。

 

第二步解耦,把Controller分离出来:

 

<div id="name" class="name" οnclick="clickName()">Jim</div>

 

把点击的行为逻辑转移到一个方法上了。

 

第三步解耦,把Controller和Model的关联关系剥离出来:

 

<div id="name" class="name">Jim</div>

借助JQuery,增加绑定方法,关联div和点击行为:

 

$("#name").click(
    function(){
        alert("");
    }
);

在后端,M和C这样的关联关系有多种实现方式,比如xml配置文件,比如注解,比如规约方式;在前端,这里采用绑定的方式关联。

 

第四步解耦,借助backbone.js,把数据和模板分离:

 

<script type="text/template" id="name-template">
    <div id="name" class="name">
        <%=name%>
    </div>
</script>

增加js代码,渲染模板:

 

window.NameView = Backbone.View.extend({
    template : _.template($('#name-template').html()),
    ……
    render: function() {
        $(this.el).html(this.template(this.model.toJSON()));
            return this;
    }
});

而渲染模板的数据通过ajax异步获取。ajax不仅仅给用户带来好的体验,也给前端程序员带来变革,它让前端页面的展示可以拆分为多个步骤,增加了解耦的可能性。

 

至此,原有的单个HTML片段已经解耦成为:M:HTML模型,View:CSS,C:JavaScript方法;同时,M和C之间的映射使用绑定方式关联,M又剥离成为模板数据两个部分。

 

文章系本人原创,转载请注明作者和出处

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值