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

基于vue的驗(yàn)證碼組件的示例代碼

 更新時(shí)間:2019年01月22日 09:37:44   作者:我在長安長安  
這篇文章主要介紹了基于vue的驗(yàn)證碼組件的示例代碼,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧

最近在自己寫頁面,模仿思否論壇,然后寫登錄注冊(cè)UI的時(shí)候需要一個(gè)驗(yàn)證碼組件. 去搜一下沒找到什么合適的,而且大多都是基于后端的,于是自己手寫一個(gè)。

演示

分析驗(yàn)證碼組件

分析驗(yàn)證碼功能

  • 隨機(jī)出現(xiàn)的數(shù)字大小寫字母 (基礎(chǔ)功能)
  • 不同的數(shù)字或者字母有不同的顏色 (功能優(yōu)化)
  • 不同的數(shù)字或者字母有不同的字體大寫 (功能優(yōu)化)
  • 不同的數(shù)字或者字母有不同的邊距 (功能優(yōu)化)
  • 不同的數(shù)字或者字母有不同的傾斜角度 (功能優(yōu)化)
  • 更多功能優(yōu)化...

分析組件功能

  • 可以設(shè)置生成驗(yàn)證碼的長度 (基本功能)
  • 可以設(shè)置驗(yàn)證碼組件的寬高 (基本功能)

編寫驗(yàn)證碼組件

template

最外層div綁定點(diǎn)擊事件,點(diǎn)擊后刷新驗(yàn)證碼。
span是單個(gè)驗(yàn)證碼的載體,樣式動(dòng)態(tài)綁定

<template>
 <div class="ValidCode disabled-select" :style="`width:${width}; height:${height}`" @click="refreshCode">
  <span v-for="(item, index) in codeList" :key="index" :style="getStyle(item)">{{item.code}}</span>
 </div>
</template>

methods

refreshCode 刷新驗(yàn)證碼的方法
createdCode 生成驗(yàn)證碼的方法
getStyle 為每個(gè)元素生成動(dòng)態(tài)的樣式

 methods: {
  refreshCode () {
   this.createdCode()
  },
  createdCode () {
   let len = this.length,
    codeList = [],
    chars = 'ABCDEFGHJKMNPQRSTWXYZabcdefhijkmnprstwxyz0123456789',
    charsLen = chars.length
   // 生成
   for (let i = 0; i < len; i++) {
    let rgb = [Math.round(Math.random() * 220), Math.round(Math.random() * 240), Math.round(Math.random() * 200)]
    codeList.push({
     code: chars.charAt(Math.floor(Math.random() * charsLen)), // 隨機(jī)碼
     color: `rgb(${rgb})`, // 隨機(jī)顏色
     fontSize: `1${[Math.floor(Math.random() * 10)]}px`, // 隨機(jī)字號(hào)
     padding: `${[Math.floor(Math.random() * 10)]}px`, // 隨機(jī)內(nèi)邊距
     transform: `rotate(${Math.floor(Math.random() * 90) - Math.floor(Math.random() * 90)}deg)` // 隨機(jī)旋轉(zhuǎn)角度
    })
   }
   // 指向
   this.codeList = codeList
   // 將當(dāng)前數(shù)據(jù)派發(fā)出去
   this.$emit('update:value', codeList.map(item => item.code).join(''))
  },
  // 動(dòng)態(tài)綁定樣式
  getStyle (data) {
   return `color: ${data.color}; font-size: ${data.fontSize}; padding: ${data.padding}; transform: ${data.transform}`
  }
 }

完整代碼

使用

<valid-code :value.sync="validCode"></valid-code>

組件

<template>
 <div class="ValidCode disabled-select" :style="`width:${width}; height:${height}`" @click="refreshCode">
  <span v-for="(item, index) in codeList" :key="index" :style="getStyle(item)">{{item.code}}</span>
 </div>
</template>

<script>
export default {
 name: 'validCode',
 props: {
  width: {
   type: String,
   default: '100px'
  },
  height: {
   type: String,
   default: '40px'
  },
  length: {
   type: Number,
   default: 4
  }
 },
 data () {
  return {
   codeList: []
  }
 },
 mounted () {
  this.createdCode()
 },
 methods: {
  refreshCode () {
   this.createdCode()
  },
  createdCode () {
   let len = this.length,
    codeList = [],
    chars = 'ABCDEFGHJKMNPQRSTWXYZabcdefhijkmnprstwxyz0123456789',
    charsLen = chars.length
   // 生成
   for (let i = 0; i < len; i++) {
    let rgb = [Math.round(Math.random() * 220), Math.round(Math.random() * 240), Math.round(Math.random() * 200)]
    codeList.push({
     code: chars.charAt(Math.floor(Math.random() * charsLen)),
     color: `rgb(${rgb})`,
     fontSize: `1${[Math.floor(Math.random() * 10)]}px`,
     padding: `${[Math.floor(Math.random() * 10)]}px`,
     transform: `rotate(${Math.floor(Math.random() * 90) - Math.floor(Math.random() * 90)}deg)`
    })
   }
   // 指向
   this.codeList = codeList
   // 將當(dāng)前數(shù)據(jù)派發(fā)出去
   this.$emit('update:value', codeList.map(item => item.code).join(''))
  },
  getStyle (data) {
   return `color: ${data.color}; font-size: ${data.fontSize}; padding: ${data.padding}; transform: ${data.transform}`
  }
 }
}
</script>

<style scoped lang="scss">
 .ValidCode{
  display: flex;
  justify-content: center;
  align-items: center;
  cursor: pointer;
  span{
   display: inline-block;
  }
 }
</style>

源碼地址

以上就是本文的全部內(nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • 淺談Vue數(shù)據(jù)響應(yīng)

    淺談Vue數(shù)據(jù)響應(yīng)

    這篇文章主要介紹了淺談Vue數(shù)據(jù)響應(yīng),Vue的數(shù)據(jù)響應(yīng)主要是依賴了Object.defineProperty(),下面就具體來介紹一下如何實(shí)現(xiàn)數(shù)據(jù)響應(yīng)
    2018-11-11
  • 解決el-menu標(biāo)題過長顯示不全問題

    解決el-menu標(biāo)題過長顯示不全問題

    本文主要介紹了如何解決el-menu標(biāo)題過長顯示不全問題,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,感興趣的朋友們跟著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-12-12
  • until封裝watch常用邏輯簡化代碼寫法

    until封裝watch常用邏輯簡化代碼寫法

    這篇文章主要介紹了until將watch最常用的邏輯進(jìn)行封裝簡化代碼寫法,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-07-07
  • Vue?使用?ElementUi?el-upload?手動(dòng)上傳文件限制上傳文件類型大小同名等進(jìn)行限制

    Vue?使用?ElementUi?el-upload?手動(dòng)上傳文件限制上傳文件類型大小同名等進(jìn)行限制

    個(gè)人在做文件上傳功能的時(shí)候,踩過不少的坑,特在此記錄下,本文介紹Vue使用?ElementUi?el-upload?手動(dòng)上傳文件限制上傳文件類型大小同名等進(jìn)行限制問題,感興趣的朋友一起看看吧
    2024-02-02
  • 解決vuex數(shù)據(jù)頁面刷新后初始化操作

    解決vuex數(shù)據(jù)頁面刷新后初始化操作

    這篇文章主要介紹了解決vuex數(shù)據(jù)頁面刷新后初始化操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2020-07-07
  • vue實(shí)現(xiàn)全選和反選功能

    vue實(shí)現(xiàn)全選和反選功能

    這篇文章主要為大家詳細(xì)介紹了vue實(shí)現(xiàn)全選和反選功能,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-08-08
  • 解決vue前端rsa加密遇到的問題message too long for RSA

    解決vue前端rsa加密遇到的問題message too long for RS

    這篇文章主要介紹了解決vue前端rsa加密遇到的問題message too long for RSA,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2024-07-07
  • Vue如何獲取元素高度總是不準(zhǔn)確的問題

    Vue如何獲取元素高度總是不準(zhǔn)確的問題

    這篇文章主要介紹了Vue如何獲取元素高度總是不準(zhǔn)確的問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-10-10
  • vue項(xiàng)目中axios的封裝請(qǐng)求

    vue項(xiàng)目中axios的封裝請(qǐng)求

    這篇文章主要介紹了vue項(xiàng)目中axios的封裝請(qǐng)求,axios?是一個(gè)輕量的HTTP客戶端,它基于?XMLHttpRequest?服務(wù)來執(zhí)行?HTTP?請(qǐng)求,支持豐富的配置,下文更多詳細(xì)資料,需要的朋友可以參考一下
    2022-03-03
  • Vue3使用JSX的方法實(shí)例(筆記自用)

    Vue3使用JSX的方法實(shí)例(筆記自用)

    以前我們經(jīng)常在react中使用jsx,現(xiàn)在我們?cè)趘ue中也是用jsx,下面這篇文章主要給大家介紹了關(guān)于Vue3使用JSX的相關(guān)資料,文中通過實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2023-02-02

最新評(píng)論