- 浏览: 313841 次
- 性别:
- 来自: 河南郑州
文章分类
最新评论
-
sillydong:
https://github.com/sillydong/CZ ...
PHP 框架 Yaf 学习笔记----默认行为 -
achun:
jocce 写道var data1={};里面放的是json数 ...
jCT 嵌入模板简化方案 -
jocce:
var data1={};里面放的是json数据吗?为什么我用 ...
jCT 嵌入模板简化方案 -
achun:
randomnany 写道hi:你说的那个所谓的bug不是bu ...
PHP 框架 Yaf 学习笔记----默认行为 -
randomnany:
hi:你说的那个所谓的bug不是bug~yaf默认的就是读取 ...
PHP 框架 Yaf 学习笔记----默认行为
一直以来都想用jCT写出个WEB可视组件,本来打算从Grid入手做的,可是实际我做的时候发现如此的纠结
jCT本来就是模板技术,而组件可以认为是一种特定的模板技术(只不过模板被写道javascript代码里面了)
有想做组件这样的想法也不奇怪,因为模板所呈现的html原代码形式,改造扩充,调整结构,增加属性相对常规组件来说都是无比的方便。
可正是这种灵活性把jCT这个方向给毁了,因为,通用组件的模板代码完全体现不出来灵活性,而且还容易把事情搞复杂,
本来直接写html模板就已经很简单了,给个判断,加个循环,弄个分页都是很简单的事情
代码说话:注释用<!--注释-->
table部分
<!---///grid recorders--> <!--grid 是子模板对象名,recorders是要传入的记录对象--> <table> <thead> <!--表头部分,于其通过配置给出这些表头名不比多写几个th方便多少,这样你还可以增加自己的class等属性--> <tr> <th>用户名</th> <th>实名</th> <th>职位</th> </tr> </thead> <tbody> <!---this.Fn.V.push(this.rows.GetView(recorders));--> <!--这个语句以前没有出现过,其实这就是jCT内部实现视图时push进输出数组的语句, 这里通过建立一个grid下的rows子模板,把循环独立出来,然后调用this.rows.GetView(recorders)并push进输出数组 来完成tbody主体,这样做的理由后面会阐述,注意recorders参数被直接给传过去了 --> <!---///rows recorders--> <!---for(var i=0;i<recorders.length;i++){var l=recorders[i];--> <!--简单的循环输出了,这里面倒是可以写一段通用的代码,不过一样很大么?后面的阐述将否定他--> <tr name="/" value="user.get" class="submitdblc"> <td name="id" value="+-l.id-+"><span name="user">+-l.user-+</span></td> <!--注意id这个写的位置,这个是我应用里面的特殊需求,和上面的name="/"是配套的--> <td name="xingming">+-l.xingming-+</td> <td name="zhiwei">+-l.zhiwei-+</td> </tr> <!---}--> <!---///rows--> </tbody> </table> <div> <!---this.Fn.V.push(page.GetView(toPages(recorders)));--> <!--分页条控制输出,toPages是一个分页的函数,后面给出代码--> </div> <!---///grid--> <!--下面是分页条控制的模板,由于这个几乎是通用的结构所以独立出来--> <!---///page p--> <div class="page"> <fieldset> <!---for(var i=p.start;i<=p.end;i++){--> <button class="pageButton" value="+-i-+">+-i-+</button> <!---}--> <button class="pageButton" value="+-p.prev-+">上9页</button> <button class="pageButton" value="+-p.next-+">下9页</button> <button class="pageButton" value="+-p.count-+">共+-p.count-+页+-p.rows-+条</button> </fieldset> </div> <!---///page-->
分页的函数,在上面的代码里面要求后台返回的recorders对象里面直接含有相关参数,当然你可以把这些参数独立出来
/* *sets是分页所需要的信息,应该又后台输出的数据给出 * page_count总页数,这个后台没有给出的话也可以在js里计算,不过那就要提共每页有多少条记录了, * 我没有这样做,我习惯直接从后台计算出来,改造他当然不是什么大问题 * page_no当前显示的页 * rows_count记录总数 *range表示每次显示多少页的可选范围,我的习惯是9,因为个人喜好当前页优先处在中心位置这种形式 *当然这个函数也是这么写的,改造这个函数为常见的非中心分页的形式也很容易 *page返回值,有了这些值足以满足分页条的显示 * start:显示的开始页码 * end:显示的结束页码 * prev:前翻range页 * next:后翻range页 * no:当前页码 * rows:rows_count记录总数 */ function toPages (sets,range){ range=range||9; var rng=Math.floor(range/2); var page={start:0,end:0,prev:0,next:0}; page.count= sets.page_count|| 0; page.no = sets.page_no || 0; page.rows=sets.rows_count||0; if(!page.no) return page; page.start=page.no-rng; if(page.start<1) page.start=1; page.end=page.no+rng; if(page.end>page.count) page.end=page.count; page.prev=page.start-rng; if(page.prev<1) page.prev=1; page.next=page.end+rng; if(page.next>page.count) page.next=page.count; return page; }
那这里面有多少成分可以组件化!我想有这些方面吧,但问题和疑问同时存在
-
表头和recorders循环部分还是给出配置方便些
是的,对于简单的需求的确可以这样做,那有没有复杂的需求呢?
有,太普遍了,我们经常会遇到明明数据给的是int型,显示要用vchar型比如这个职位
就很可能是个id,显示确要用vchar,
呵呵,你说:后台给出的数据的时候用联合查询就OK了
没错,可以这样,不过当有更多的联合查询出现后,效率就不高了,其实这种情况多数时候是可以做成数据字典
在前台用js替换的,那我们是对数据进行前台前期预处理还是直接写到模板里呢?
我推崇直接写到模板里,为何这样!因为这只是一个特殊需求,相应的类似特殊需求也许会有一大堆,
也许替换数据字典后还需要保存原始的int值的比如职位模板部分可以这样写<td name="zhiwei" value="+-l.zhiwei-+">+-dict.zhiwei[l.zhiwei]-+</td>
看上去td有value这样的属性很古怪,但是这确实让整个结构和取值便的简单了,
如何取这个value我们就不谈了,这不并麻烦,但是如果你直接用jQuery的val方法的话,无疑是不行的
因为基于这种设计的val取值是有优先级的,也就是value属性优先,如果没有就取innerHTML了 -
排序,双击表头标题可以排序
的确这是个真正的需求,后续文章我会给出一个方案 -
编辑修改
其实不管是及时的双击弹出对话框修改还是cell直接修改,如果你使用jQuery这样的框架的话加一个class
然后写一段$('table.dbleditbox tr').live('dblclick',yourfunc);
就OK了这样的话上面保留职位的原始int值就凸显出意义了,那有读者说这不是也可以组件化么!
呵呵注意了:上面用的可是live呀,整个前台设置一个就可以生效了
其实也有例外,那就是有些dialog组件停止了event冒泡,可我认为这是dialog组件自身的问题, -
分页的请求需要传递给后台以及修改数据的提交
的确,如果仅仅看我上面的模板代码一些读者会一头雾水,这个咋提交请求!
我说这是模式问题,如果我们做一个组件就设计一种提交以及参数传递方法,那学习成本不是很高,代码重复不是很高!
<tr name="/" value="user.get" class="submitdblc">
看到这种写法了吧,用一个特殊的name="/"而他的value就是提交给后台的请求方法,至于参数的变更可以用统一的开发模式来设计定义,一个方法就满足这类需求
但是这已经不属于组件设计问题了,这是开发模式问题,修改提交同样是这样
到此问题终于找到关键,组件VS设计模式,我们已知的组件确实是绑定了自己的设计模式,对开发者确实有不少限制,前台模板确实给了开发者自由,但同时也需要开发者摸索出自己的一条路,才能通行无阻。
jCT的
纠结
:对于复杂应用,开发者要有自己的设计模式才能"得道飞升”,因为复杂应用用组件的需求更大,是仔细的研究组件,还是从设计模式入手,写自己的代码,是个艰难的选择
可以确定的是 前台 模板+设计模式的代码量,灵活性都要远胜于纯组件,前台模板下应该是根据应用需求分类设计模板,形成制定的“组件”,自己及时书写的组件,不要忘记了jCT是编译型模板,最后的执行代码是可以独立保存成独立的js的(看来应该写一个这样的导出方法了),貌似分页条就可以独立成组件,如此小的组件,我咋都觉得还不如直接复制粘贴模板的方便
发表评论
-
前台模板 Element 属性渲染的思考
2010-03-27 11:03 0jCT 一直是在前台解 ... -
jCT的纠结,前台模板下Grid基础版
2009-12-20 03:04 1862SVN已经更新.最新下载:jCT最新版本 ... -
jCT 3.9.12.10 放出,大改变,文档重新发布
2009-12-10 23:35 3297SVN已经更新.最新下载:jCT最新版本 ... -
基于jCT前台模板设计要点备注
2009-04-19 16:54 0第一个通讯是获得用户角色,获取用户是否登录及相关信息,因 ... -
jCT3改如何改进,边想边发
2009-03-26 11:28 1620ps:新版已经发布,请看 新版文档 ============ ... -
2008中国开源软件竞赛揭晓jCT榜上有名
2008-12-30 21:07 1634今天查收的邮件发现的,获得了优秀技术创新奖 的最后一名--- ... -
jCT 3更新--为发展调整代码结构
2008-12-04 15:01 1637SVN已经更新.最新下载:jCT最新版本 更多信息请看 ... -
jCT 嵌入模板简化方案
2008-11-13 09:38 2761本文代码在线演示 http://jsct.googlecod ... -
无独有偶,另一个采用原生js语法的js template工具EJS
2008-11-10 10:14 4658EJS开源主页: http://code.google.c ... -
jCT 使用教程之[UI组件]Tree
2008-10-29 15:42 1784SVN已经更新.最新下载: ... -
jCT 3正则版测试,正则就是慢
2008-09-10 00:19 1713我在jCT的说明中提到,jCT为了保障速度,没有用正则。今天我 ... -
jCT与AJAX七宗罪
2008-09-08 20:33 2616jCT的更多信息请看我博 ... -
jCT 第三版简要文档
2008-09-07 14:26 5892SVN已经更新.最新下载:jCT最新版本 更多信息请看 ... -
jCT 在实战中洗礼,jCT要成为终极的javascript前台模板
2008-09-06 10:44 1604说在前面 : 由于目前正在用jCT的第三版实作项目,在项目中 ... -
jCT 使用教程之[嵌入模板]
2008-09-02 11:20 2497更多信息请看我博客里的jCT专题 ,或者jCT开源主页示例 ... -
js模板编译器jCT,推荐/问题贴
2008-08-27 09:58 1821jCT的更多信息请看我博客里的jCT专题 ,或者jCT开源主 ... -
javascript 模板编译器jCT----的梦想
2008-08-23 10:31 2600模板是什么 ? 模板是把数据和表现组装到一起的工具,是WEB开 ... -
jCT 第三版简要文档,此文档已经废弃,留作历史
2008-07-11 11:47 1386JavaScript Common Templates 第 ... -
都变了样!我这样用jCT模板.
2008-07-02 14:58 1660在写这篇文章的时候我相信很多朋友都不明白我在说什么,会奇怪我这 ... -
jCT 第三版预览,已废弃,留作历史
2008-06-26 17:31 1401重新进行了设计,抛弃了所有重新定义javascript固有语法 ...
相关推荐
JCT 2557-2020 规范
JCT 2558-2020 规范
标准 JCT174-2005无碱玻璃纤维带
JCT 2177-2021 硅藻泥装饰壁材
JCT 621-2021 硅酸盐建筑制品用生石灰
JCT 1017-2020 建筑防水材料用聚合物乳液
JCT 2560-2020 结构密封胶
这个名为"JCT"的工具包提供了丰富的功能,使得开发者在Java应用中集成加密和解密操作变得更加简单。下面我们将详细探讨Java加密的相关知识点以及可能在JCT中涉及的技术。 1. **对称加密**:这是最常见的加密方式,...
JCT 60006-2020 瓷砖薄贴法施工技术规程
JCT 620-2021 石灰取样方法
JCT 618-2019化学解析方法
JCT 2561-2020 金属复合板
JCT 2041-2020 聚氨酯灌浆材料
Report of Subjective Test Results of Responses to the Joint Call for Proposals (CfP) on Video Coding Technology for High Efficiency Video Coding (HEVC)所应用的测试序列
JCT 949-2021 混凝土制品用脱模剂
JCT 1057-2021 玻璃纤维增强水泥(GRC)外墙板
JCT 2604-2021 仿石型混凝土面板和面砖
JCT 为java开发者提供实用、方便、简洁的加密和解密相关的工具代码。1.0版提供Blowfish,SHA与MD5数字摘要,PBE基于口令的加密,RSA算法工具类,使这些算法更容易在编成中使用.文件包中含源码、文档、class包WDSsoft:...
JCT 60003-2019
JCT 2567-2020