Vue组件开发之LeanCloud带图形校验码的短信发送功能
有15万开发者使用LeanCloud服务,其中不乏知乎、懂球帝、爱范儿、拉卡拉等知名应用,LeanCloud提供了数据存储、即时消息……等一站式服务,并从常用的用户管理需求出发,提供了邮箱验证、短信验证……等用户账户相关的服务。 为防止攻击者恶意发送海量短信造成用户账户损失并影响正常业务,LeanCloud推出了免费图形校验码服务,并且可以在应用设置中设置“强制短信验证服务使用图形校验码”。 Vue是目前使用较广泛的三大前端框架之一,其数据驱动及组件化的特性使得前端开发更为快捷便利。 LeanCloud提供的由客户发起的短信发送场景主要有用户验证、用户密码重置,虽然不是很多场景,但如果每个场景下都单独进行图形校验码相关开发,则费时费力且对一些需要统一设置的参数调整不够灵活。 组件命名为Mobile,基于Element-UI的Form组件和Input组件进行开发,如果用户对布局和样式有特殊要求,只需要改为自己相应的组件,或者使用原生HTML元素并设置样式即可,同时需要将Element-UI提供的$message改为自己相应的API调用。 组件行为开发的Mobile组件用于发送短信验证码,因此需要能够输入手机号码和图形校验码,并可触发发送短信的动作,触发发送短信动作成功后,需要禁用发送短信功能,并进行倒计时,倒计时结束后才能重新发送短信。 因此具体的组件行为主要是以下几点:
其中发送短信的行为必须调用不同场景下的API,因此我们需要将此按钮绑定的事件emit到父组件,由父组件决定具体调用哪个API。 组件props从上述组件行为出发,分析需要传入组件的props:
组件的props选项如下: 组件模板中,与props相关的考量主要有如下三方面: 组件的根元素是一个el-form组件,其label-width属性绑定到来自父组件的labelWidth属性, 手机号码输入框使用el-input组件,绑定到value属性,要实现双向绑定,不能直接使用v-model进行数据绑定,而是要将v-model绑定转换为v-bind:value属性绑定和@input事件绑定, (间接)发送短信按钮的禁用状态。发送短信按钮的禁用状态由倒计时的计数器组件data数据触发,当该数据不为0时,发送短信的按钮禁用。倒计时触发方式是通过父组件中绑定的smsSent属性,因此需要在子组件中watch该属性,并在该值为真是设置倒计时计数器,并通过setInterval进行倒计时。 图形校验码加载为在组件加载时显示图形校验码,需要在组件的mounted生命周期钩子中调用LeanCloud的API。 在 绑定函数还需要传入第二个参数,这是一个含有success和error方法的对象,用于提供图形校验码校验成功和失败的操作。 发送短信验证码发送短信验证码在传递的第二个参数对象的success方法中进行,在这里,我们首先更新组件的smsSent属性为false,这样,当在父组件中实际完成短信发送之后设置smsSent为true时才会触发针对smsSent属性的watcher,同时,需要注意在父组件中绑定smsSent属性时,必须使用.sync修饰符。然后向父组件emit自定义sendSmsCode事件,并将success回调时的validateToken参数透传过去。 {
captcha.bind({
textInput: this.$refs.captcha.$el.children[0],image: this.$refs.captchaImage,verifyButton: this.$refs.sendSms.$el
},{
success: (validateToken) => {
this.$emit('sendSmsCode',validateToken)
},error: () => {
this.$message.error('请输入正确的图形校验码!')
}
})
})
}
组件使用首先在父组件的组件选项中添加包含Mobile组件的components,然后在模板中添加mobile组件。 其中绑定sendSmsCode事件的方法如下: {
this.mobileForm.smsSent = true
})
},
完整组件代码 总结以上所述是小编给大家介绍的Vue组件开发之LeanCloud带图形校验码的短信发送功能。编程之家 52php.cn 收集整理的教程希望能对你有所帮助,如果觉得编程之家不错,可分享给好友!感谢支持。 (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
- 什么是C名称查找在这里? (&GCC对吗?)
- Postgresql – 用于Postgres的GitLab Omnibus配置
- vb打包问题
- c# – 将csv文件/ excel导入到sql数据库asp.net中
- ruby-on-rails – ENOTFOUND:getaddrinfo ENOTFOUND api.h
- fl2440的U-boot-2010.09移植(四) 添加NOR Flash启动支持
- cocos2d-x lua 屏幕适配问题(OpenGL调用),版本号(cocos2dx
- reactjs – React-Bootstrap Popover不符合ADA
- 创建一个c#函数来比较int结果
- Webpack系列——手把手教你使用Webpack搭建简易的React开发