当前位置: 首页 > news >正文

制作app的网站佛山高明

制作app的网站,佛山高明,用cn作网站行么,公司企业网站建设多少钱文章目录 前言介绍代码场景例子优缺点后言 前言 hello world欢迎来到前端的新世界 😜当前文章系列专栏:前端设计模式 🐱‍👓博主在前端领域还有很多知识和技术需要掌握,正在不断努力填补技术短板。(如果出现错误&#…

文章目录

  • 前言
  • 介绍
  • 代码
  • 场景例子
  • 优缺点
  • 后言

前言

hello world欢迎来到前端的新世界


😜当前文章系列专栏:前端设计模式
🐱‍👓博主在前端领域还有很多知识和技术需要掌握,正在不断努力填补技术短板。(如果出现错误,感谢大家指出)🌹
💖感谢大家支持!您的观看就是作者创作的动力

介绍

  • 策略模式简单描述就是:对象有某个行为,但是在不同的场景中,该行为有不同的实现算法。把它们一个个封装起来,并且使它们可以互相替换

代码

<html>
<head><title>策略模式-校验表单</title><meta content="text/html; charset=utf-8" http-equiv="Content-Type">
</head>
<body><form id = "registerForm" method="post" action="http://xxxx.com/api/register">用户名:<input type="text" name="userName">密码:<input type="text" name="password">手机号码:<input type="text" name="phoneNumber"><button type="submit">提交</button></form><script type="text/javascript">// 策略对象const strategies = {isNoEmpty: function (value, errorMsg) {if (value === '') {return errorMsg;}},isNoSpace: function (value, errorMsg) {if (value.trim() === '') {return errorMsg;}},minLength: function (value, length, errorMsg) {if (value.trim().length < length) {return errorMsg;}},maxLength: function (value, length, errorMsg) {if (value.length > length) {return errorMsg;}},isMobile: function (value, errorMsg) {if (!/^(13[0-9]|14[5|7]|15[0|1|2|3|5|6|7|8|9]|17[7]|18[0|1|2|3|5|6|7|8|9])\d{8}$/.test(value)) {return errorMsg;}                }}// 验证类class Validator {constructor() {this.cache = []}add(dom, rules) {for(let i = 0, rule; rule = rules[i++];) {let strategyAry = rule.strategy.split(':')let errorMsg = rule.errorMsgthis.cache.push(() => {let strategy = strategyAry.shift()strategyAry.unshift(dom.value)strategyAry.push(errorMsg)return strategies[strategy].apply(dom, strategyAry)})}}start() {for(let i = 0, validatorFunc; validatorFunc = this.cache[i++];) {let errorMsg = validatorFunc()if (errorMsg) {return errorMsg}}}}// 调用代码let registerForm = document.getElementById('registerForm')let validataFunc = function() {let validator = new Validator()validator.add(registerForm.userName, [{strategy: 'isNoEmpty',errorMsg: '用户名不可为空'}, {strategy: 'isNoSpace',errorMsg: '不允许以空白字符命名'}, {strategy: 'minLength:2',errorMsg: '用户名长度不能小于2位'}])validator.add(registerForm.password, [ {strategy: 'minLength:6',errorMsg: '密码长度不能小于6位'}])validator.add(registerForm.phoneNumber, [{strategy: 'isMobile',errorMsg: '请输入正确的手机号码格式'}])return validator.start()}registerForm.onsubmit = function() {let errorMsg = validataFunc()if (errorMsg) {alert(errorMsg)return false}}</script>
</body>
</html>

场景例子

  • 如果在一个系统里面有许多类,它们之间的区别仅在于它们的’行为’,那么使用策略模式可以动态地让一个对象在许多行为中选择一种行为。
  • 一个系统需要动态地在几种算法中选择一种。
  • 表单验证

优缺点

优点

  • 利用组合、委托、多态等技术和思想,可以有效的避免多重条件选择语句
  • 提供了对开放-封闭原则的完美支持,将算法封装在独立的strategy中,使得它们易于切换,理解,易于扩展
  • 利用组合和委托来让Context拥有执行算法的能力,这也是继承的一种更轻便的代替方案

缺点

  • 会在程序中增加许多策略类或者策略对象
  • 要使用策略模式,必须了解所有的strategy,必须了解各个strategy之间的不同点,这样才能选择一个合适的strategy

后言

创作不易,要是本文章对广大读者有那么一点点帮助 不妨三连支持一下,您的鼓励就是博主创作的动力

http://www.yayakq.cn/news/176786/

相关文章:

  • 广州微网站建设价位爱牛网络
  • 五里店网站建设广州越秀网站制作
  • 开发手机网站用什么好处全球推广
  • 天河建设网站服务如何做网站价格策略
  • 网站建设的行业客户设计开发程序
  • 如何在电子商务化平台上做企业网站推广广州安全教育平台
  • 做我网站黔东南网站建设gzklyy
  • 做外贸都得有网站吗找别人建网站去哪里
  • 网络公司网站绪论wordpress推荐插件
  • 广州网站设计服务商计算机网络网站开发
  • 网站和后台建设手机版的网站怎么做
  • 航佳网站建设公司邮箱名称
  • 无锡企业网站制作价格银川网站建设价格
  • 全国建筑人才求职招聘网站泰安网站建设收费标准
  • 设计师做兼职的网站有哪些百度渠道开户哪里找
  • 电商网站平台宜昌电子商城网站建设
  • 装修网站线怎样做dede网站怎么做单页面
  • 高水平高职建设网站金蝶进销存软件免费版
  • ssh蒙语网站开发网站软文代写
  • 深圳网站建设制作公司网页设计结论与心得
  • 做网站运营需要注意哪些问题潮汕学院网站开发
  • 黄冈个人网站建设平台wordpress 媒体文件库
  • 企业网站网络推广松岗做网站哪家便宜
  • 网站设计怎么做ppt答辩国外网站加速
  • 哪里有免费 建设网站的地址怎么做网页宣传
  • 网站制作价格app开发定制公司哪家
  • 网站seo优化如何做外贸线上推广
  • 搭建网站需要做什么网页游戏排行2020前十名
  • 网站建设步骤实践报告wordpress分类目录样式
  • 网站建设的可行性分析百度搜索网页版入口