二十二、HTML5单页框架View.js介绍 - 视图配置

不需要 Npm 的单页应用框架:

View.js - http://view-js.com


在正式介绍视图配置的功能作用之前,我们先来看一看我们在面临『相似而又不同』的需求时,我们是如何处理的。

在这里插入图片描述
如上图所示,我们同时面临3个需求需要满足(这些需求可能是同时提出的,也可能是一个需求满足后而又提出的其它需求),这些需求有相当一部分是重合,可以共用的,但是彼此时间又互有差异之处。

通常的做法,是先满足一个需求,然后将重叠部分的逻辑硬拷贝多份,转而以其为基础分别实现需求B和需求C。

这样做当然可行,但潜在的维护成本就会一下子高出了很多.因为我们都清醒地认识到当代码衍生出多个副本的时候,开发团队就难免会遇到代码同步的问题:

在副本A中发现的故障,需要同步在副本B、副本C中解决;
在副本B中丰富的功能,需要同步至副本A、副本C中;

随着项目的进一步开展和功能的进一步丰富,将会出现 “相比功能开发或故障解决而言,代码同步工作会耗费更多的精力”的情况。虽然我们耿耿于怀,越来越担心,但似乎一直找不到合适、优雅的解决办法。

怎么办?
先从思路上做出改变:

将需求A、需求B和需求C合并开发,使用配置决定工作模式

在这里插入图片描述
亦即,开发者可以将需求A和需求B,以及需求C在同一载体上同时实现,然后借助配置工具通过配置决定功能的具体工作模式。
对View.js而言,这个载体就是视图,配置工具,就是视图配置。

借助视图配置,开发者可以将视图开发为多种形态的综合体,最终以视图配置的方式指定视图的具体工作模式或表现形式。
例如,开发者可以使用视图配置轻松实现如下需求:

注册界面的密码长度,软件定制客户A要求在6-20位,软件定制客户B要求在4-10位。

代码如下所示:

var view = View.ofId("register");
 
/* 默认配置:密码最少位数 */
view.config.get("password-min-length").setValue(10);
 
/* 默认配置:密码最多位数 */
view.config.get("password-max-length").setValue(20);

view.find(".submit").addEventListener("click", function(){
    var pwd = pwdObj.value.trim();
 
    var minLen = view.config.get("password-min-length").getValue(),
        maxLen = view.config.get("password-max-length").getValue();
 
    if(pwd.length < min){
        alert("密码长度不能少于" + minLen + "位");
        return;
    }
 
    if(pwd.length > max){
        alert("密码长度不能多于" + maxLen + "位");
        return;
    }
});

客户A的配置:


/* 重载既有配置:密码最少位数 */
view.config.get("password-min-length").setValue(6, true);/* 第二个参数用于复写可能已经存在的值,如果不传且已经有值,则赋值无效,相当于什么也没做 */
 
/* 重载默认配置:密码最多位数 */
view.config.get("password-max-length").setValue(20, true);

客户B的配置:


/* 重载既有配置:密码最少位数 */
view.config.get("password-min-length").setValue(4, true);/* 第二个参数用于复写可能已经存在的值,如果不传且已经有值,则赋值无效,相当于什么也没做 */
 
/* 重载默认配置:密码最多位数 */
view.config.get("password-max-length").setValue(10, true);

[第一篇]
[上一篇 - 初始化] [下一篇 - 日志输出]

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值