欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

vue實現移動端多格輸入框

 更新時間:2021年10月20日 14:39:00   作者:夢想家小阿新  
這篇文章主要為大家詳細介紹了vue實現移動端多格輸入框,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下

近來公司提出需求,完成如下圖h5頁面操作。

網上沒什么輪子可以使用,就自己徒手擼了一個。不多廢話,直接上代碼。

<div class="verify-tel">
    <h1>短信驗證</h1>
    <h2>SMS Verification</h2>
    <div>
        <input ref="pwd"   :maxlength="digits.length" v-model="msg"  style="position: absolute;z-index: -1;opacity: 0"/>
        <ul  class="pwd-wrap" @click="focus">
            <li v-for="(item,key) in digits" :style="{'margin-right': (100-10*digits.length)/(digits.length-1)+'%','width':'10%'}" >
                <span v-if="msgLength > key">{{msg.substring(key,key+1)}}</span>
            </li>
        </ul>
    </div> 
</div>

css部分(樣式內容過于繁瑣,請自行省去修改)

html,body{
    width: 100%;
    height: 100%;
    background: #fbf9fe;
  }
  .verify-tel{
    background-color: #f9f9f9;   
    margin: 0 30px;
    >p{
      color: red;
      font-weight: bold;
      margin-top: 40px;
      margin-bottom: 30px;
    }
    >h1{
      font-weight: 400;
      margin-bottom: 0;
    }
    >h2{
      margin-top: 0;
      font-weight: 400;
      font-size: 14px;
      color: #858585;
    }
    .input-box{
      margin-top: 30px;
      >input{
        width: 10%;
        border: none;
        border-bottom: 1px solid grey;
        background-color: #f9f9f9;
        text-align: center;
        margin-right: 18%;
        font-size: 35px;
        &:focus{
          border-bottom: 1px solid deepskyblue;
        }
        &:last-of-type{
          margin-right: 0 !important;
        }
      }
    }
    .btn-box{
      >button{
        height: 40px;
        border: 1px solid #4e8cee;
        color: #4e8cee;
        background-color: white;
        border-radius: 4px;
        width: 30%;
        &:last-of-type{
          float: right;
          width: 65%;
          height: 40px;
          color: white;
          background-color: rgb(78,140,238);
          border-radius: 4px;
        }
      }
    }
  }
  .pwd-wrap{
    padding-left: 0;
    width: 100%;
    height: 44px;
    padding-bottom: 1px;
    margin: 0 auto;
    display: flex;
    display: -webkit-box;
    display: -webkit-flex;
    cursor: pointer;
    border: none;
    background-color: #f9f9f9;
  }
  .pwd-wrap li{
    list-style-type:none;
    text-align: center;
    line-height: 44px;
    -webkit-box-flex: 1;
    flex: 1;
    -webkit-flex: 1;
    border: none;
    border-bottom:1px solid black;
    background-color: #f9f9f9;
    &:last-of-type{
      margin-right: 0 !important;
    }
    >span{
      font-size: 20px;
    }
  }
  .pwd-wrap li:last-child{
    border-right: 0;
  }
  .pwd-wrap li i{
    height: 10px;
    width: 10px;
    border-radius:50% ;
    background: #000;
    display: inline-block;
  }

js部分代碼

<script>
  export default{
    data(){
      return {
        page:0,    //1為短信驗證
        digits:['','','','','',''],  //input框位數控制,這里可以配置多少個“輸入框”
        msg:'',
        msgLength:0,
      }
    },
    methods:{
      //手機號碼驗證接口函數
      verifyTels:async function () {
        try{
        }catch(e){
          console.log(e)
        }
      },
      //使input框獲得焦點
      focus(){
        this.$refs.pwd.focus(); 
      },
    },
    beforeMount:function () {
        //這里因為我的業(yè)務需求存在多個page,且digits由父組件傳輸過來,故我隱去,只剩下一句代碼。
        this.page=1;
    },
    watch: {
      msg(curVal){
        //監(jiān)聽輸入的長度,如果輸入完,自動調用校驗接口函數
        if(curVal.trim().length===this.digits.length){
           this.verifyTels(); 
        }
        this.msgLength = curVal.length;
      },
      'page':{
        handler:function (newValue, oldValue) {
          if(oldValue==0&&newValue==1){
            //第一次進入頁面,自動獲得焦點,這里可優(yōu)化。
            this.timer = setTimeout(()=>{this.$refs.pwd.focus()},500);
          }
        },
        deep:true
      }
    },
    beforeDestroy:function () {
      clearTimeout(this.timer);
    }
  }
</script>

如果有問題,聯系本人修改。方便大家使用

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

相關文章

  • Vue項目webpack打包部署到服務器的實例詳解

    Vue項目webpack打包部署到服務器的實例詳解

    這篇文章主要介紹了Vue項目webpack打包部署到服務器的實例詳解的相關資料,需要的朋友可以參考下
    2017-07-07
  • Vue中靈活拖拽的前端神器VueDraggablePlus的用法詳解

    Vue中靈活拖拽的前端神器VueDraggablePlus的用法詳解

    這篇文章主要介紹了一款功能強大、靈活易用的前端組件VueDraggablePlus,作為前端工程師,我們經常會遇到需要實現拖拽功能的場景,而VueDraggablePlus正是為了解決這一痛點而誕生的,讓我們一起來看看它的特點和用法吧
    2024-03-03
  • 在vue項目中使用sass的配置方法

    在vue項目中使用sass的配置方法

    這篇文章主要介紹了在vue項目中使用sass的配置方法,需要的朋友可以參考下
    2018-03-03
  • vue+element實現批量刪除功能的示例

    vue+element實現批量刪除功能的示例

    下面小編就為大家分享一篇vue+element實現批量刪除功能的示例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-02-02
  • Vue3中按需引入ECharts詳細步驟(一看就會)

    Vue3中按需引入ECharts詳細步驟(一看就會)

    新項目采用Vue3作為前端項目框架,避免不了要使用echarts,這篇文章主要給大家介紹了關于Vue3中按需引入ECharts的相關資料,需要的朋友可以參考下
    2023-09-09
  • Vue項目History模式404問題解決方法

    Vue項目History模式404問題解決方法

    本文主要解決Vue項目使用History模式發(fā)布到服務器Nginx上刷新頁面404問題。小編覺得挺不錯的,現在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-10-10
  • vue實現拖拽進度條

    vue實現拖拽進度條

    這篇文章主要為大家詳細介紹了vue實現拖拽進度條,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-03-03
  • 詳解Vue項目在其他電腦npm run dev運行報錯的解決方法

    詳解Vue項目在其他電腦npm run dev運行報錯的解決方法

    這篇文章主要介紹了詳解Vue項目在其他電腦npm run dev運行報錯的解決方法,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-10-10
  • Vue實現關聯頁面多級跳轉(頁面下鉆)功能的完整實例

    Vue實現關聯頁面多級跳轉(頁面下鉆)功能的完整實例

    這篇文章主要給大家介紹了關于Vue實現關聯頁面多級跳轉(頁面下鉆)功能的相關資料,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2021-03-03
  • vue封裝動態(tài)表格方式詳解

    vue封裝動態(tài)表格方式詳解

    這篇文章主要為大家介紹了vue封裝動態(tài)表格方式示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-08-08

最新評論