widget模式弄不出来_Widget模式

Widget模式

Widget模式是指借用Web Widget思想将页面分解成组件,针对部件开发,最终组合成完整的页面,Web Widget指的是一块可以在任意页面中执行的代码块,Widget模式不属于一般定义的23种设计模式的范畴,而通常将其看作广义上的架构型设计模式。

描述

模块化开发使页面的功能细化,逐一实现每个功能模块来完成系统需求,这是一种很好的编程实践,在简单模板模式实现的模板引擎的帮助下可以非常方便的完成这个实例,这将更适合多人团队开发,降低相互之间因为功能或者视图创建的耦合影响概率,组件的多样化也能够组建更加丰富的页面,同样也会让组件的复用率提高。

实现

// dom.js

F.module("./dom", function() {

return {

g: function(id) {

return document.getElementById(id);

},

html: function(id, html) {

if (!html) return this.g(id).innerHTML;

else this.g(id).innerHTML = html;

}

}

});

// template.js

F.module("./template", function() {

/***

* 模板引擎,处理数据的编译模板入口

* @param str 模块容器id或者模板字符串

* @param data 渲染数据

**/

var _TplEngine = function(str, data) {

// 如果数据是数组

if (data instanceof Array) {

// 缓存渲染模板结果

var html = "";

// 数据索引

var i = 0;

// 数据长度

var len = data.length;

// 遍历数据

for (; i < len; i++) {

// 缓存模板渲染结果,也可以写成

// html += arguments.callee(str, data[i]) ;

html += _getTpl(str)(data[i]);

}

// 返回模板渲染最终结果

return html;

} else {

// 返回模板渲染结果

return _getTpl(str)(data);

}

};

/***

* 获取模板

* @param str 模板容器id,或者模板字符串

**/

var _getTpl = function(str) {

// 获取元素

var ele = document.getElementById(str);

// 如果元素存在

if (ele) {

// 如果是input或者textarea表单元素,则获取该元素的value值,否则获取元素的内容

var html = /^(textarea | input)$/i.test(ele.nodeName) ? ele.value : ele.innerHTML;

// 编译模板

return _compileTpl(html);

} else {

// 编译模板

return _compileTpl(str);

}

};

// 处理模板

var _dealTpl = function(str) {

// 左分隔符

var _left = "{%";

// 右分隔符

var _right = "%}";

// 显示转化为字符串

return String(str)

// 转义标签内的{%if(a<b)%}

->
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值