- ubuntu12.04环境下使用kvm ioctl接口实现最简单的虚拟机
- Ubuntu 通过无线网络安装Ubuntu Server启动系统后连接无线网络的方法
- 在Ubuntu上搭建网桥的方法
- ubuntu 虚拟机上网方式及相关配置详解
CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.
这篇CFSDN的博客文章从表单校验看JavaScript策略模式的使用详解由作者收集整理,如果你对这篇文章有兴趣,记得点赞哟.
众所周知的是,表单确实在前端,唔,或者说在网页中占有不小的比重。事实上,几乎每一个中大型网站都会有“登录注册”以验证用户信息、防止一些不可名状的隐患。。.
那么表单的优劣就成了前端开发者急需解决的问题。其实我更愿意称为“代码的可读性”或“可复用性”以及“是否冗杂”.
表单也有“优劣”?你在开玩笑嘛? 我想你可以认真看下下面的代码,它用到了一些“新知识”:
1
2
3
4
5
6
|
<form action=
"xxx"
id=
"registerForm"
>
请输入用户名:<input type=
"text"
name=
"userName"
id=
"name"
/>
请输入密码:<input type=
"text"
name=
"password"
id=
"pass"
/>
请输入手机号:<input type=
"text"
name=
"phoneNumber"
id=
"phone"
/>
<button>提交</button>
</form>
|
用户名、密码、手机号这应该是表单中最常见的了,好,我们就以此分析! 。
上面这些只是简单的演示效果,你完全可以用css的valid/invalid、HTML5的required/pattern来配合完成.
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
|
<script>
var
registerForm=document.getElementById(
'registerForm'
)
registerForm.onsubmit=
function
(){
if
(registerForm.userName.value==
''
){
document.getElementById(
"name"
).setCustomValidity(
'用户名不能为空'
);
return
false
;
}
if
(registerForm.password.value.length<6){
document.getElementById(
"pass"
).setCustomValidity(
'密码长度不能少于6位'
);
return
false
;
}
if
(!/(^1[3|5|8][0-9]{9}$)/.test(registerForm.phoneNumber.value)){
document.getElementById(
"phone"
).setCustomValidity(
'手机号码格式不正确'
);
return
false
;
}
}
</script>
|
但即使这样,你也不会觉得它很完美 —— 现在表单只有三条,如果某一天它增加到了N条,即使是「复制粘贴」也拯救不了你! 。
就在这时,你想到了 策略模式 (看,JS总是会让你“灵光一现”) 说起策略模式,很自然地,要遵循 暴露接口和实现逻辑分离 的原则.
策略模式指的是定义一系列的算法,把它们一个个封装起来。将不变的部分和变化的部分隔开是每个设计模式的主题,策略模式也不例外, 策略模式的目的就是将算法的使用与算法的实现分离开来 。 一个基于策略模式的程序至少由两部分组成。第一个部分是一组策略类,策略类封装了具体的算法,并负责具体的计算过程。第二个部分是环境类 Context,Context 接受客户的请求,随后把请求委托给某一个策略类。要做到这点,说明 Context 中要维持对某个策略对象的引用 ——《JavaScript设计模式与开发实践》 。
那么,第一步我们很显然要把这些校验逻辑都封装成【策略对象】:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
|
var
strategies={
isNoneEmpty:
function
(value,errorMsg){
if
(value===
''
){
return
errorMsg;
}
},
minLength:
function
(value,length,errorMsg){
if
(value.length<length){
return
errorMsg;
}
},
isMobile:
function
(value,errorMsg){
if
(!/(^1[3|5|8][0-9]{9}$)/.test(value)){
return
errorMsg;
}
}
};
|
接下来我们要实现一个“暴露出去的”、“作为调用的”方法类 —— 它将作为context(上下文),负责接收用户的请求并委托给验证对象stratrgies:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
|
var
Validator=
function
(){
this
.cache=[];
//用于保存接收到的校验规则
};
Validator.prototype.add=
function
(dom,rule,errorMsg){
var
ary=rule.split(
':'
);
this
.cache.push(
function
(){
var
strategy=ary.shift();
ary.unshift(dom.value);
ary.push(errorMsg);
return
strategies[strategy].apply(dom,ary);
//调用strategies对象的指定方法对象,并规定在函数对象内部this指向dom元素,ary作为参数传入
});
};
Validator.prototype.start=
function
(){
for
(
var
i=0,validatorFunc;validatorFunc=
this
.cache[i++];){
var
msg=validatorFunc();
if
(msg){
return
msg;
}
}
}
|
使用:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
|
var
validataFunc=
function
(){
var
validator=
new
Validator();
//添加校验规则
validator.add(registerForm.userName,
'isNoneEmpty'
,
'用户名不能为空'
);
validator.add(registerForm.password,
'minLength:6'
,
'密码长度不能少于6位'
);
validator.add(registerForm.phoneNumber,
'isMobile'
,
'手机号码格式不正确'
);
var
errMsg=validator.start();
//获得校验结果
return
errorMsg;
//返回
}
var
registerForm=document.getElementById(
'registerForm'
)
registerForm.onsubmit=
function
(){
var
errorMsg=validataFunc();
if
(errorMsg){
//触发错误提示
return
false
;
//并阻止表单提交
}
}
|
我们可以看到的是:当我们往 validator 对象里添加完一系列的校验规则之后,会调用 validator.start() 方法来启动校验。如果 validator.start() 返回了一个确切的 errorMsg 字符串当作返回值,说明该次校验没有通过,此时需让 registerForm.onsubmit 方法返回 false 来阻止表单的提交.
这样确实比之前好很多:至少在我们修改验证规则时显得毫不费力:
1
|
validator.add(registerForm.userName,
'minLength:2'
,
'用户名不能少于2位'
)
|
但是问题也就随之而来了:我们把对于用户名的验证规则“不能为空”改为了“不能少于两位”,那么就不能验证“是否为空”了.
能不能像element-ui一样可以自定义多种验证规则 呢?就像这样:
1
2
3
4
5
6
7
|
validator.add(registerForm.userName,[{
strategy:
'isNoneEmpty'
,
errorMsg:
'用户名不能为空'
},{
strategy:
'minLength:2'
,
errorMsg:
'用户名长度不能少于2位'
}])
|
现在“rule”是数组-对象的形式了,我们需要把add函数改一下:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
|
Validator.prototype.add=
function
(dom,rules){
var
self=
this
;
for
(
var
i=0,rule;rule=rules[i++];){
(
function
(rule){
var
strategyAry=rule.strategy.split(
':'
);
var
errorMsg=rule.errorMsg;
self.cache.push(
function
(){
var
strategy=strategyAry.shift();
strategyAry.unshift(dom.value);
return
strategies[strategy].apply(dom,strategyAry);
});
})(rule)
}
}
|
策略模式的优点:
利用组合、委托、多态等技术和思想,可以有效地避免多重条件选择语句(关于这一点,笔者在 这篇文章 中做了详细说明);完美实现了设计模式都应该具有的“对外开放-封闭”原则,基于策略模式实现的规则大多易于扩展、易于使用避免了大量CV的工作 。
到此这篇关于从表单校验看JavaScript策略模式的使用详解的文章就介绍到这了,更多相关JavaScript策略模式使用内容请搜索我以前的文章或继续浏览下面的相关文章希望大家以后多多支持我! 。
原文链接:https://blog.csdn.net/qq_43624878/article/details/107934317 。
最后此篇关于从表单校验看JavaScript策略模式的使用详解的文章就讲到这里了,如果你想了解更多关于从表单校验看JavaScript策略模式的使用详解的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。
作者:小林coding 计算机八股文网站:https://xiaolincoding.com 大家好,我是小林。 今天跟大家聊聊,常见的缓存更新策略。 Cache Aside(旁路缓存)策略; Rea
我使用 git 多年,最近为了一个项目改用 mercurial。在过去的 6 个月里,我已经学会了如何通过命令行很好地使用 Mercurial。 这可能是我的想象,但在我看来,mercurial 在
这个问题适合任何熟悉的人 Node.js express Passport 带有 Passport 的 JWT 身份验证(JSON Web token ) Facebook OAuth2.0 或谷歌
在 Coq 中,当试图证明记录的相等性时,是否有一种策略可以将其分解为所有字段的相等性?例如, Record R := {x:nat;y:nat}. Variables a b c d : nat.
我正在处理的项目目前只有一个 Bootstrap 文件,用于初始化应用程序中的所有 javascript 对象。类似于下面的代码 if(document.getElementById('nav'))
我正在考虑使用 OpenLDAP 在首次登录时添加密码到期和强制更改密码。 似乎使用 ppolicy 覆盖来实现这一点。 当我在 ppolicy.schema 中看到这个时,我开始使用 ppolicy
这基本上是我昨天问的一个问题的重新陈述,因为我得到的一个答案似乎没有理解我的问题,所以我一定是不清楚。我的错。 因为 WPF 依赖于 DirectX,所以它对卡和驱动程序的内部非常敏感。我有一个案例,
我是单点登录(SSO)概念的新手。我开始知道 SAML 请求和响应是实现 SSO 流程的最佳方式。然后我开始阅读有关 SAML2.0 的信息。我来了一个术语 NameIdPolicy 在 saml1.
关闭。这个问题需要更多 focused .它目前不接受答案。 想改进这个问题?更新问题,使其仅关注一个问题 editing this post . 5年前关闭。 Improve this questi
关闭。这个问题是opinion-based 。目前不接受答案。 想要改进这个问题吗?更新问题,以便 editing this post 可以用事实和引文来回答它。 . 已关闭 9 年前。 Improv
在 Azure 上创建新的 SQL 数据库时,它将“计算+存储”选项设置为“2 vCore + 32GB 数据最大大小”作为默认配置,但我不想使用 vCore,我可以更改它。但问题是,是否可以通过策略
我希望创建一项策略,防止在未启用身份验证的情况下创建应用服务(仅审核它们是不够的)。 以下策略可以正确识别未启用身份验证的现有资源: { "mode": "All", "policyRule"
我正在尝试从现有 AuditIfNotExists 策略创建 DeployIfNotExists 策略。部署时不会出错,但会错误提示“没有相关资源与策略定义中的效果详细信息匹配”。当评估政策时。当我将
我正在尝试从现有 AuditIfNotExists 策略创建 DeployIfNotExists 策略。部署时不会出错,但会错误提示“没有相关资源与策略定义中的效果详细信息匹配”。当评估政策时。当我将
我正在使用 wunderground 的 json api 来查询我网站上的天气状况。 api 为我提供了一个包含所有必要数据的漂亮 json 对象,但我每天只能进行多次调用。存储这些数据的首选方式是
我有一个名为可视化数据结构的项目。我有这样的 OOP 设计。 Class VisualDataStructures extends JFrame Class ControlPanel extends
这个问题在这里已经有了答案: 关闭 14 年前。 副本: Use javascript to inject script references as needed? Javascript 没有任何指
Android 应用程序遇到了一些 ANR 问题,因此我实现了 StrictMode 策略。以前从未使用过这个,所以希望有人可以帮助解释以下内容: 为什么日志显示 2 个看似相似的违规行为,除了前 4
我目前正在尝试解决一个问题。假设我们在路上行驶,我们知道路上有 10 家酒店。每家酒店都有 0 到 6 星。我的问题是:找到选择星级酒店的最佳解决方案。唯一的问题是:您不能回头去参观您已经决定不去的酒
我正在将我的应用程序迁移到 MVP。从这个 konmik 中获得了有关静态演示者模式的提示 这是我的简要 MVP 策略。为简洁起见,删除了大部分样板和 MVP 监听器。这个策略帮助我改变了方向,证明了
我是一名优秀的程序员,十分优秀!