文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

vue如何实现登陆页面

2023-06-30 17:03

关注

这篇文章主要介绍“vue如何实现登陆页面”,在日常操作中,相信很多人在vue如何实现登陆页面问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”vue如何实现登陆页面”的疑惑有所帮助!接下来,请跟着小编一起来学习吧!

分几个部分考虑,

一、输入框input的校验:1、blur时没有值和格式不符合的逻辑校验
2、限制输入长度逻辑,比如手机号只能11位,验证码只能6位。
二、验证码按钮逻辑
1、不同状态下验证码颜色,文案,是否能点击,是否显示记数需要兼顾。
2、验证码能够正常点击是在手机号格式正确情况下,所以这里要有个监听手机号,一旦格式符合,验证码生效
3、关于计数器的逻辑。

以下会从上面的点开考虑:

一、input的校验没有可说的,记住俩点,一个控制输入长度,一个控制格式。

格式校验

handleblurtel(){      let phoneCodeVerification = /^[1][3,4,5,7,8][0-9]{9}$/;     if(this.form.tel===''){       this.errorTxt="请输入手机号码" // 不同情况下错误提示     }else if(!phoneCodeVerification.test(this.form.tel)){       this.errorTxt="请输入正确的手机号码格式"     }else{       this.errorTxt='' //有效情况记得清空错误提示       return true     }   }, // 验证码必填和格式验证   handleblurcode(){     if(this.form.code===''){       this.errorTxtcode="请输入验证码"     }else if(this.form.code.length>0&&this.form.code.length<6){       this.errorTxtcode="请输入正确的验证码格式"     }else{       this.errorTxt=''       return true     }   }

长度控制

 // 限制输入的字符串长度    hanldeInputTel(){//手机号长度保证11位      if(this.form.tel.length>11){        this.form.tel=this.form.tel.slice(0,11)      }    },    handleInputCode(){//验证码保证6位      if(this.form.code.length>6){        this.form.code=this.form.code.slice(0,6)      }    },

二、验证码逻辑:

贴下html代码:

 <van-field    v-model="form.code"     center    clearable    label="短信验证码"    :error-message="errorTxtcode"    placeholder="请输入短信验证码"    @input="handleInputCode"    @blur="handleblurcode"      >    <template #button>      <button size="small" :disabled="btnStatus" :class="btnStyle" type="primary" @click="clickCode">        <van-count-down :time="time" format="ss" v-if="countFlag===1" @finish="finishDown"></van-count-down>        <span>{{countTxt}}</span>      </button>    </template>  </van-field>

vue如何实现登陆页面

vant-count-down是vant组件自带的计数器用法,直接引入,time是初始化时间数,比如60s,1min,format是时间格式:时分秒,秒等。
@finish是自带的方法,具体api可去官方网站看,这里不做介绍。

初始化按钮状态:

data(){    return {      form:{        tel:'',        code:''      },      errorTxt:'',// 手机号错误提示      errorTxtcode:'',// 验证码错误提示      btnStatus:true,// 按钮不可点击       btnStyle: 'nomalStyle',// 促初始化按钮样式       time:60*1000,// 时间数       countTxt:'发送验证码',// 初始化按钮文案       countFlag:0//0:展示文案,1;展示计数,开始计时    }    },

开始计时:
按钮状态不可点击状态btnStatus,按钮样式:btnStyle,开始计数:countFlag

// 点击按钮开始计时    clickCode(){      this.btnStatus=true      this.btnStyle=`countdown`      this.countFlag=1//开始计时      this.countTxt=''//文案为空    },

倒计时结束后:需要修改这些参数
按钮可继续点击btnStatus,显示文案countFlag,c文案内容countTxt

//  倒计时结束    finishDown(){       this.btnStyle=`canClick`       this.btnStatus=false       this.countTxt='重新获取'       this.countFlag=0    },

按钮状态何时触发:
手机号符合格式情况下,watch里面监听手机号

 watch:{   form: {      handler() {        if(/^[1][3,4,5,7,8][0-9]{9}$/.test(this.form.tel)){         this.btnStyle = 'canClick'          this.btnStatus=false        }else{         this.btnStatus=true        }      },      immediate: true,      deep: true    }  },

vue如何实现登陆页面

最后点击提交的简单写法:

// 提交用户信息    sumbit(){      let telStatus=this.handleblurtel()      let codeStatus=this.handleblurcode()      if(telStatus&&codeStatus){        this.axios.get({}).then(res=>{          console.log('提交成功')          // 把后端会的token存入前端缓存          localStorage.setItem('token',res.data.toekn)          // 跳转到首页          this.$router.push({path:'/'})        })      }    },

1,2,3步可以一步一步来,这样思路就会清晰,不然会觉得验证码一会儿这样显示一会儿那样显示,就会很混乱,所以先把单个功能开发完,最后写按钮变化前提条件 这样思路就很明确。

样式放在文末:

.nomalStyle {    background: #EAEEFD;    color: #5E6679;  }  button {      width: 161px;      height: 61px;      border-radius: 31px;      line-height: 61px;      font-size: 24px;      text-align: center;    }    .canClick {    background-color: #3E64D4;    color: #FFFFFF;  }   .countdown {    background: #EAEEFD;    color: #3E64D4  }

到此,关于“vue如何实现登陆页面”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注编程网网站,小编会继续努力为大家带来更多实用的文章!

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     807人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     351人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     314人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     433人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     221人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯