公众号基本的绑定手机号页面(截取code,手机号正则,验证码倒计时)

话不多说,直接上代码:

<template>

  <div id="home">

    <div class="bind_box">

      <div class="bindphone">

        <div class="bind_title">

          <p>绑定手机号</p>

        </div>

        <div class="phone">

          <div class="phone_left">

            <span>手机号</span>

            <input name="phone" type="number" placeholder="请输入手机号" v-model="phone" @change="change">

          </div>

          <div class="phone_right" v-if='show'>请填写正确手机号!</div>

        </div>

        <div class="phone">

          <div class="phone_left">

            <span>验证码</span>

            <input type="text" placeholder="请输入验证码" @change="codeed">

          </div>

          <div class="phone_right" v-show="sendAuthCode" @click="getma">

            <span class="getcode">获取验证码</span>

          </div>

          <div class="phone_right getcoded" v-show="!sendAuthCode">

            <span class="getcode"><span>{{auth_time}} </span> 秒后重新发送</span>

          </div>

        </div>

        <div class="codetishi" v-if="showcode">

          验证码错误!

        </div>

        <div class="sub_box" v-if="showsub">

          <div class="sub" @click="sub">

            <p>确定</p>

          </div>

        </div>

        <div class="sub_box" v-if="hidesub">

          <div class="sub">

            <p>确定</p>

          </div>

        </div>

      </div>

    </div>

  </div>

</template>

<script>

  import http from 'axios'

  import api from '@/assets/js/index'

  export default {

    name: 'home',

    data () {

      return {

          phone:'',

          code:'',

          tiancode:'',

          msgphone:'',

          show:false,

          showcode:false,

          sendAuthCode:true,/*布尔值,通过v-show控制显示‘获取按钮’还是‘倒计时’ */

          auth_time: 0, /*倒计时 计数器*/

          showsub:true,

          hidesub:false

      }

    },

    created(){


    },

    methods:{

      change:function(e){

        this.phone = e.target.value

      },

      getma:function(){

        this.checkMobile(this.phone)

        if(this.show == false){

          //获取验证码

          http.post(`${api.api}/user/checkCode`,

          {

              tel:this.phone

          })

          .then((res) => {

            console.log(res)

              this.code = res.data.data

          })

          .catch((error) => {

              console.log(error);

          });

        }

      },

      codeed:function(e){

        this.tiancode = e.target.value

        document.body.addEventListener('focusout', function () {

            window.scrollTo(0,0);

        })

      },

      qiehuan(){

        this.showsub = false,

        this.hidesub = true

      },

      sub:function (){

        if(localStorage.getItem('token')){//如果从主页进来,有用户信息,不调getUser

          //判断手机号是否被注册

          // console.log(this.phone)

          http.post(`${api.api}/user/checkTel`,

          {

              tel:this.phone,

          })

          .then((res) => {

              if(res.data.msg == 'success' && this.phone.length != 0){

                this.$messagebox('提示', '该手机号已被注册').then(action=>{

                  this.$router.push({path:'/assistant',query:{}})

                })

              }else if(res.data.msg == 'fail' && this.code ==  this.tiancode && this.phone.length != 0 && this.tiancode.length != 0){

                var id = JSON.parse(localStorage.getItem('token')).id

                console.log(id+'111')

                //绑定手机号手机号

                http.post(`${api.api}/user/updateTel`,

                {

                    id:id,

                    tel:this.phone,

                })

                .then((res) => {

                    console.log(res)

                    if(res.data.code == 0){

                      this.qiehuan()

                      this.$messagebox('提示', '绑定成功').then(action => {

                        localStorage.setItem('phone',this.phone)

                          this.$router.push({path:'/assistant',query:{}})

                      })

                    }

                })

                .catch((error) => {

                    console.log(error);

                });

              }else if(res.data.msg == 'fail' && this.code !=  this.tiancode){

                this.showcode = true

                this.$router.push({path:'/',query:{}})

              }

          })

          .catch((error) => {

              console.log(error);

          });

        }else{//如果从其他方式进入页面,没有用户信息,截取code,调取getUser

          //获取code

          var code = this.GetQueryString('code')

          var pid = window.location.hash.split('=')[1]

          console.log(code)

          console.log(pid)

          http.post(`${api.api}/getUser`,

          {

            code:code,

            pid:pid

          })

          .then((res) => {

              var id = res.data.data.id

              if(res.data.code == 0){

                localStorage.setItem('token',JSON.stringify(res.data.data))

                //判断手机号是否被注册

                // console.log(this.phone)

                http.post(`${api.api}/user/checkTel`,

                {

                    tel:this.phone,

                })

                .then((res) => {

                    console.log(this.phone.length)

                    if(res.data.msg == 'success' && this.phone.length != 0){

                      this.$messagebox('提示', '该手机号已被注册').then(action => {

                        this.$router.push({path:'/assistant',query:{}})

                      })

                    }else if(res.data.msg == 'fail' && this.code ==  this.tiancode && this.phone.length != 0 && this.tiancode.length != 0){

                      //绑定手机号手机号

                      http.post(`${api.api}/user/updateTel`,

                      {

                          id:id,

                          tel:this.phone,

                          pid:pid

                      })

                      .then((res) => {

                          if(res.data.code == 0){

                            this.$messagebox('提示', '绑定成功').then(action => {

                              localStorage.setItem('phone',this.phone)

                              this.$router.push({path:'/assistant',query:{}})

                            })

                          }

                      })

                      .catch((error) => {

                          console.log(error);

                      });

                    }else if(res.data.msg == 'fail' && this.code !=  this.tiancode){

                      this.showcode = true

                      this.$router.push({path:'/',query:{}})

                    }

                })

                .catch((error) => {

                    console.log(error);

                });

              }

          })

          .catch((error) => {

              console.log(error);

          })

        }

      },

      //验证手机号,错误提示请填写正确手机号,并做60秒倒计时

      checkMobile(phone) {

        var reg_phone = /^[1][0-9][0-9]{9}$/;

        var regPhone = new RegExp(reg_phone);

        if (regPhone.test(phone)) {

            this.show = false

            if(this.phone.length != 0){

              this.sendAuthCode = false;

              this.auth_time = 60;

              var auth_timetimer =  setInterval(()=>{

                  this.auth_time--;

                  if(this.auth_time<=0){

                      this.sendAuthCode = true;

                      clearInterval(auth_timetimer);

                  }

              }, 1000)

            }

        } else {

            this.show = true

        }

      },

      //截取地址栏code

      GetQueryString(name) {

var reg = new RegExp("(^|&)" + name + "=([^&]*)(&|$)");

var r = window.location.search.substr(1).match(reg);

if (r != null) return unescape(r[2]);

return null;

}

    }

  }

</script>

<!-- Add "scoped" attribute to limit CSS to this component only -->

<style scoped>

.bind_box{

  width:100%;

  height:100%;

  position: absolute;

  left:0;

  top:0;

  background: rgb(244,244,244);

  display: flex;

  align-items: center;

}

.bindphone{

  width:90%;

  margin:auto;

  background:#fff;

  border-radius:10px;

}

.bind_title{

  width:100%;

  text-align: center;

  padding:50px 0 30px 0;

  box-sizing: border-box;

  font-size:30px;

}

.phone{

  width:90%;

  height:110px;

  line-height: 110px;

  margin:auto;

  border-bottom:1px solid #ccc;

  box-sizing: border-box;

  display: flex;

  flex-direction: row;

}

.phone_left{

  width:62%;

  height:100%;

}

.phone_left input{

  width:50%;

  height:90%

}

.phone_right{

  width:38%;

  height:100%;

  color:red;

}

.phone span{

  font-size:28px;

}

.phone input{

  outline:none;

  font-size: 25px;

  border:0;

}

.getcode{

  display: inline-block;

  width:100%;

  height:70px;

  line-height: 70px;

  text-align: center;

  border-radius:10px;

  background: rgb(0,135,236);

  color:#fff;

}

.getcoded{

  width:45%;

}

.sub_box{

  width:90%;

  margin:auto;

  padding:100px 0;

  box-sizing: border-box;

}

.sub{

  width:100%;

  height:80px;

  border-radius:50px;

  background: rgb(0,135,236);

  text-align: center;

  line-height: 80px;

  color:#fff;

  box-sizing: border-box;

  font-size:30px;

}

.codetishi{

  width:90%;

  height:110px;

  line-height: 110px;

  margin:auto;

  font-size:30px;

  color:red;

}

</style>

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 206,214评论 6 481
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 88,307评论 2 382
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 152,543评论 0 341
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 55,221评论 1 279
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 64,224评论 5 371
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,007评论 1 284
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,313评论 3 399
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,956评论 0 259
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 43,441评论 1 300
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,925评论 2 323
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,018评论 1 333
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,685评论 4 322
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,234评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,240评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,464评论 1 261
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,467评论 2 352
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,762评论 2 345

推荐阅读更多精彩内容