位置: 编程技术 - 正文

Vue组件开发之LeanCloud带图形校验码的短信发送功能(vuejs组件开发实例)

编辑:rootadmin

推荐整理分享Vue组件开发之LeanCloud带图形校验码的短信发送功能(vuejs组件开发实例),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:vue常用组件开发,vue组件开发的原理,vue组件开发规范,vue组件用法,vue 组件开发,vue怎么开发组件,vue 组件开发,vue怎么开发组件,内容如对您有帮助,希望把文章链接给更多的朋友!

有万开发者使用LeanCloud服务,其中不乏知乎、懂球帝、爱范儿、拉卡拉等知名应用,LeanCloud提供了数据存储、即时消息……等一站式服务,并从常用的用户管理需求出发,提供了邮箱验证、短信验证……等用户账户相关的服务。

为防止攻击者恶意发送海量短信造成用户账户损失并影响正常业务,LeanCloud推出了免费图形校验码服务,并且可以在应用设置中设置“强制短信验证服务使用图形校验码”。

Vue是目前使用较广泛的三大前端框架之一,其数据驱动及组件化的特性使得前端开发更为快捷便利。

LeanCloud提供的由客户发起的短信发送场景主要有用户验证、用户密码重置,虽然不是很多场景,但如果每个场景下都单独进行图形校验码相关开发,则费时费力且对一些需要统一设置的参数调整不够灵活。

组件命名为Mobile,基于Element-UI的Form组件和Input组件进行开发,如果用户对布局和样式有特殊要求,只需要改为自己相应的组件,或者使用原生HTML元素并设置样式即可,同时需要将Element-UI提供的$message改为自己相应的API调用。

组件行为

开发的Mobile组件用于发送短信验证码,因此需要能够输入手机号码和图形校验码,并可触发发送短信的动作,触发发送短信动作成功后,需要禁用发送短信功能,并进行倒计时,倒计时结束后才能重新发送短信。

因此具体的组件行为主要是以下几点:

提供一个输入手机号的输入框,该输入框内容可以由用户输入,也可以从用户信息中获取。 提供一个输入图形校验码的输入框。 页面加载完毕显示图形校验码。 提供一个发送短信的按钮,用户点击发送短信的按钮,校验图形校验码,若校验通过,使用手机号码,并以图形校验码校验返回的validataionToken作为option参数发送短信。 短信发送成功,禁用发送短信的按钮,启动定时器进行倒计时,倒计时结束后恢复发送短信的按钮。 组件使用Element-UI的Form组件的布局,需要考虑el-form的labelWidth标签宽度设置与父组件中的el-form匹配。

其中发送短信的行为必须调用不同场景下的API,因此我们需要将此按钮绑定的事件emit到父组件,由父组件决定具体调用哪个API。

组件props

从上述组件行为出发,分析需要传入组件的props:

表示手机号码属性。我们发送短信验证码的目的是最终用于后续的验证或密码重置操作,可以从外部传入,并且能够在组件内部修改后返回父组件,因此该属性必须是双向绑定的,Vue组件中双向绑定的属性有两种,一是自定义v-model,属性名必须是value,一是可以使用.sync修饰符绑定的属性,这里将手机号码属性设置为Mobile组件的v-model属性,属性名为value。 通知Mobile组件短信已发送的属性。属性名为smsSent,类型为Boolean,以禁用发送短信的按钮,并启动倒计时。 el-form的labelWidth属性。设置默认值,并接受来自父组件中传递的数据以保持与父组件中其他元素/组件布局一致。

组件的props选项如下:

组件模板中,与props相关的考量主要有如下三方面:

Vue组件开发之LeanCloud带图形校验码的短信发送功能(vuejs组件开发实例)

组件的根元素是一个el-form组件,其label-width属性绑定到来自父组件的labelWidth属性, <el-form ref="mobile-form"> 。

手机号码输入框使用el-input组件,绑定到value属性,要实现双向绑定,不能直接使用v-model进行数据绑定,而是要将v-model绑定转换为v-bind:value属性绑定和@input事件绑定, <el-input :value="value" @input="value => $emit('input', value)"> ,这样就可以实现“v-model透传”。

(间接)发送短信按钮的禁用状态。发送短信按钮的禁用状态由倒计时的计数器组件data数据触发,当该数据不为0时,发送短信的按钮禁用。倒计时触发方式是通过父组件中绑定的smsSent属性,因此需要在子组件中watch该属性,并在该值为真是设置倒计时计数器,并通过setInterval进行倒计时。

图形校验码加载

为在组件加载时显示图形校验码,需要在组件的mounted生命周期钩子中调用LeanCloud的API。

在AV.Captcha.request()的回调中绑定校验码输入框、图形校验码元素以及发送短信按钮元素,绑定参数对象的三个属性均可以是表示元素id的string或实际HTMLElement,由于我们创建的是Vue组件,因此直接使用组件的$refs属性来指定实际HTMLElement,需要注意的是,el-input中input元素是ref的$el属性的children[0],而el-button中button元素是ref的$el。

绑定函数还需要传入第二个参数,这是一个含有success和error方法的对象,用于提供图形校验码校验成功和失败的操作。

发送短信验证码

发送短信验证码在传递的第二个参数对象的success方法中进行,在这里,我们首先更新组件的smsSent属性为false,这样,当在父组件中实际完成短信发送之后设置smsSent为true时才会触发针对smsSent属性的watcher,同时,需要注意在父组件中绑定smsSent属性时,必须使用.sync修饰符。然后向父组件emit自定义sendSmsCode事件,并将success回调时的validateToken参数透传过去。

组件使用

首先在父组件的组件选项中添加包含Mobile组件的components,然后在模板中添加mobile组件。

其中绑定sendSmsCode事件的方法如下:

完整组件代码

总结

以上所述是小编给大家介绍的Vue组件开发之LeanCloud带图形校验码的短信发送功能,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对积木网网站的支持!

vue-router路由与页面间导航实例解析 vue-router是Vue.js官方的路由插件,它和vue.js是深度集成的,适合用于构建单页面应用。vue的单页面应用是基于路由和组件的,路由用于设定访问路径,并

vue实现仿淘宝结账页面实例代码 虽然Vue最强大的是组件化开发,但是其实多页面开发也蛮适合的。下面小编给大家分享vue实现仿淘宝结账页面实例代码,具体内容大家参考下本文。这

AngularJs 终极购物车(实例讲解) 废话不多说,直接上代码:!DOCTYPEhtmlhtmllang="en"headmetacharset="UTF-8"title购物车/titlescriptsrc="angularjs/angular.js"/scriptstyle.box{width:%;border-bottom:1pxsolidsilver;}.box1{

标签: vuejs组件开发实例

本文链接地址:https://www.jiuchutong.com/biancheng/375897.html 转载请保留说明!

上一篇:vue组件父子间通信详解(三)(vue 父子组件通信)

下一篇:vue-router路由与页面间导航实例解析(请简述vue-router路由的作用)

  • 小微企业印花税怎么算
  • 汇算清缴补交所得税会计分录小企业会计政策
  • 税务师考哪5门
  • 减免的企业所得税需要计入应交税费吗
  • 招聘预算费用包括哪些预算清单
  • 福利费用属于工资吗
  • 百旺税控盘汇总表怎么看
  • 农产品一般纳税人开普票免税吗
  • 增值税计算为什么是销项减进项
  • 公积金是上个月的还是本月的
  • 电子发票认证显示未开具
  • 音乐茶座取什么名字好呢
  • 分配辅助生产车间成本记账凭证
  • 破产企业公司还要交税吗
  • 企业利息收入的税率是多少
  • 非独立核算分公司个税怎么申报
  • 申报退税金额是0是怎么回事
  • 增值税抵扣凭证包括桥闸通行费发票
  • 小规模纳税人金额
  • 房屋销售佣金能退回吗
  • 外购商品用于招待怎么做账
  • 新企业残保金免交三年超过30人
  • 商品进销差价的核算方法
  • 外贸出口支付方式
  • 增值税附加税怎么计提
  • 财务费用算营业利润吗
  • 向境外企业支付服务费代扣代缴什么税
  • win11开机蓝屏怎么解决
  • 什么是盈余公积和资本公积
  • nvcpl.dll是什么
  • php sybase_fetch_array使用方法
  • 提取的坏账准备怎么算
  • 特许权使用费属于销售收入吗
  • vue编写网页
  • 应付未付工资企业所得税
  • 延期收款利息如何缴税
  • 银行手续费未开发票
  • 非营利组织增值税
  • 云计算技术是学什么的
  • 应收账款应付账款属于什么科目
  • php中的九大缓存技术
  • vue clonedeep
  • Win11 Build 25336 预览版发布:Snap 窗口新增最近 20 个标签选项
  • es restful api文档
  • 什么发票才能做账务处理
  • 个人所得税银行卡未实名认证是什么意思
  • 劳务报酬可以专项附加扣除吗
  • 帝国cms如何使用
  • 待报解预算收入是什么意思,扣了钱
  • 固定资产改扩建和大修理的区别
  • 社保工伤保险可以退吗
  • mysql操作步骤
  • sqlserver 恢复数据库
  • 小规模企业可以抵扣进项税吗
  • 资本公积金转增股本是利好吿
  • 公司一般户的钱怎么拿出来
  • 对方要求先开发票怎么办
  • 弥补企业以前年度亏损 顺序
  • 销售成本包括销项税额吗
  • 发现错账后进行错账更正的方式
  • winxp系统怎么连接网络
  • wrme.exe是什么
  • anddroid.process.acore进程停止什么意思
  • winoldap.exe - winoldap进程是什么意思
  • win8怎么看windows
  • win10系统笔记本怎么连接wifi
  • linux创建.c
  • cocos2dx粒子效果
  • Unity3D游戏开发pdf
  • window.requestAnimationFrame是什么意思,怎么用
  • jquery教程chm
  • jquery示例
  • python正则函数
  • bootstrap轮播效果
  • python函数详解
  • 河南工商年检网上申报
  • 开发票收多少税点?
  • 员工的生育津贴计入工资总额吗
  • 北京朝阳区电话区号是多少?
  • 什么是审计的重要特征,也是审计的精髓
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设