zoukankan      html  css  js  c++  java
  • DWZjs分析报告

    DWZjs分析报告

    设计思路

    第一次打开页面时载入界面到客户端, 之后和服务器的交互只是数据交互, 不会占用界面相关的网络流量. 支持HTML扩展方式来调用DWZ组件. 标准化Ajax开发, 降低Ajax开发成本.

    优点

    • 完全开源,源码没有做任何混淆处理,方便扩展
    • CSS和js代码彻底分离,修改样式方便
    • 简单实用,扩展方便,轻量级框架,快速开发
    • 仍然保留了html的页面布局方式
    • 支持HTML扩展方式调用UI组件,开发人员不需写js
    • 只要懂html语法不需精通js,就可以使用ajax开发后台
    • 基于jQuery,UI组件以jQuery插件的形式发布,扩展方便
    • 可以快速生成一些简单的项目原型

    缺点

    • 缺乏企业项目中一些常用的组件,比如可编辑列表,树形列表,弹出选择组件等复杂控件.
    • javaeye有讨论说dwz不太稳定,存在一些兼容性的问题.这个我还不确定.
    • 开发环境和它的技术环境都非常冷,没有找到成功的商业案例,它的论坛在这里http://bbs.dwzjs.com/.

    技术分析

    DWZ简单扩展了html标准, 给HTML定义了一些特别的class 和attribute. DWZ框架会找到当前请求结果中的那些特别的class 和attribute, 并自动关联上相应的js处理事件和效果. 下面举一个简单的用户列表页面进行简要的说明:

    <a class="delete" href="__URL__/foreverdelete/id/{sid_user}/navTabId/__MODULE__" target="navTabTodo" title="你确定要删除吗?" warn="请选择用户"><span>删除</span></a>
    <a class="edit" href="__URL__/edit/id/{sid_user}" target="dialog" mask="true" warn="请选择用户"><span>编辑</span></a>
    <a class="icon" href="__URL__/password/id/{sid_user}" target="dialog" mask="true" warn="请选择用户"><span>修改密码</span></a>
    <table class="list" width="100%" layoutH="116">
          <thead>
          <tr>
                <th width="60">编号</th>
                <th width="100">用户名</th>
                <th>昵称</th>
                <th>Email</th>
                <th width="100">添加时间</th>
                <th width="120">上次登录</th>
                <th width="80">登录次数</th>
                <th width="80">状态</th>
          </tr>
          </thead>
          <tbody>
          <volist id="vo" name="list">
                <tr target="sid_user" rel="{$vo['id']}">
                      <td>{$vo['id']}</td>
                      <td>{$vo['account']}</td>
                      <td>{$vo['nickname']}</td>
                      <td>{$vo['email']}</td>
                      <td>{$vo['create_time']|date="Y-m-d",###}</td>
                      <td>{$vo['last_login_time']|date="Y-m-d H:i:s",###}</td>
                      <td>{$vo['login_count']}</td>
                      <td>{$vo['status']|showStatus=$vo['id']}</td>
                </tr>
          </volist>
          </tbody>
    </table>

    上面的html示例代码支持一个简单用户的查询,编辑,修改和删除功能.

    1. 整个过程是这样子的,html渲染后,dwz会遍历整个document文档,查找一个具体特殊属性比如target,class的dom,并为之关联上相应的样式和js事件.
    2. 比如上例中的 <table class="list" width="100%" layoutH="116"> ,dwz会将识别为列表,调用相应的列表生成程序.并将表格的高度调整为116.
    3. 注意到上例中,有个 volist 标签,DWZ将其识别为一个模板.这个有点类似于jsp中的javabean模板,不过后台要传递的是一个list JSON对象,dwz会遍历这个模板对象,循环生成用户的相关信息.
    4. 删除、编辑、修改密码使用了变量 {sid_user}
      • <tbody>中<tr target="sid_user" rel="{$vo['id']}">
      • 当选中一行时,tr上的rel值会自动替换到url变量中.
      • 注意url变量名{sid_user}和tr的target="sid_user"保持一致.

    初步结论

    仅仅只是个人的观点,相比extjs组件式开发来说,dwzjz更接近html.这是一种非常好的设计方式,学习起来也没有什么门槛. 但它或许不适合做工业企业MES,它没有成功的商业案例,前景不可测.

    一个可行的方案

    一个可行的方案是以dwzjs框架为基础,整合其它比如jquery grid plugin,jstree plugin插件作为内部框架来推广.但这会带来设计风格不统一,布局不统一的危险.同时也会带来的相应的学习成本上升,管理混乱的趋势,因为已经上线项目的关系,我们肯定还要维护原有的前端框架.
  • 相关阅读:
    「专题总结」后缀自动机
    「专题总结」回文自动机
    「专题总结」后缀数组
    2.11毕设进度
    2.10毕设进度
    2.09毕设进度
    2.08毕设进度
    2.07毕设进度
    2.06毕设进度
    2.05毕设进度
  • 原文地址:https://www.cnblogs.com/ms_config/p/1954519.html
Copyright © 2011-2022 走看看