如何使用canvas顯示驗證碼

這篇文章主要介紹了如何使用canvas顯示驗證碼,具有一定借鑒價值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓小編帶著大家一起了解一下。

創(chuàng)新互聯(lián)堅持“要么做到,要么別承諾”的工作理念,服務領域包括:成都網(wǎng)站設計、網(wǎng)站制作、企業(yè)官網(wǎng)、英文網(wǎng)站、手機端網(wǎng)站、網(wǎng)站推廣等服務,滿足客戶于互聯(lián)網(wǎng)時代的曲周網(wǎng)站設計、移動媒體設計的需求,幫助企業(yè)找到有效的互聯(lián)網(wǎng)解決方案。努力成為您成熟可靠的網(wǎng)絡建設合作伙伴!

最近做了一個小需求,就是點擊刪除按鈕,彈出提示彈框讓你輸入驗證碼確認刪除。

那么怎么顯示從后臺獲取的驗證碼供用戶輸入呢?我在理解需求時還以為是后臺直接把驗證碼發(fā)到用戶的手機上 然后讓其輸入,其實不然,我理解錯了,應該用 canvas 把驗證碼畫出來。

理解需求之后我扒著有驗證碼的網(wǎng)址看,開始 canvas 畫圖之旅。

技術棧: quasar (基于vue的一種框架) / canvas

點擊刪除按鈕,觸發(fā)彈框彈出

如何使用canvas顯示驗證碼

彈框為什么會彈出呢? 因為點擊刪除按鈕,觸發(fā) handleAddDialogOpened 事件,使得data里面的 addDialogOpened 由false變成true,彈框就由之前的不顯示變成顯示啦。

如圖代碼是彈框代碼:其中 canvas 標簽上的 ref 是多余的,抱歉吶,忘記刪掉了

如何使用canvas顯示驗證碼 

data 里面定義的數(shù)據(jù):定義 canvas 畫布的寬高

verifyCode_ 綁定用戶輸入input框的驗證碼

如何使用canvas顯示驗證碼 

computed 計算屬性里面 mapState 映射 verifyCode 數(shù)據(jù), mapState 是輔助函數(shù),用于幫助我們簡化生成計算屬性,不懂的可以扒著 vuex 的官網(wǎng)瞅瞅

如何使用canvas顯示驗證碼 

mapActions 也是輔助函數(shù),用于將組件的方法映射為 store.dispatch

getVerifyCode 就是向后臺獲取驗證的請求方法

如何使用canvas顯示驗證碼 

canvasclick 方法用于 當用戶辨認不清驗證碼,或者輸入錯誤重新輸入時,點擊 換一個 即可更新驗證碼(此時要重新從后臺獲取驗證碼) 后臺小哥哥不打烊吶~~~

如何使用canvas顯示驗證碼 

核心代碼: drawPic() 方法就是畫驗證碼的核心方法

1 獲取畫布標簽 使用 getElementById 原生獲取 dom

2 使用 .getContext('2d') 準備畫布 .textBaseline 定義畫布描繪的基線

3 繪制背景

4 繪制驗證碼

5 繪制干擾視覺的線和點

如何使用canvas顯示驗證碼 

drawText() 繪制驗證碼的方法

如何使用canvas顯示驗證碼 

drawLine() 繪制干擾線的方法

如何使用canvas顯示驗證碼 

drawDot() 繪制干擾點的方法

如何使用canvas顯示驗證碼 

定義彈框彈出的方法以及刪除的方法, 回歸需求 ,到此這個需求就完成了 可以和后臺聯(lián)調(diào),沒啥問題就可提交代碼啦

如何使用canvas顯示驗證碼 

總結:

a. 遇到?jīng)]有做過的需求,要去看看別人怎么做的,目前還沒有難到要你自己創(chuàng)新,沒有任何類比的代碼

b. 善于使用debugger調(diào)試代碼,看看自己代碼那里出了問題,有bug不要慌,喝口水,去debugger打斷點深入理解代碼執(zhí)行邏輯,效率解決

c. 作為社畜大軍的一員,要自律, 要輸出 ,要鍛煉,有時間還要看看代碼大全,地鐵上擼擼MDN文檔,扎實js, 期待那個你想成為的你, 共勉

感謝你能夠認真閱讀完這篇文章,希望小編分享的“如何使用canvas顯示驗證碼”這篇文章對大家有幫助,同時也希望大家多多支持創(chuàng)新互聯(lián),關注創(chuàng)新互聯(lián)行業(yè)資訊頻道,更多相關知識等著你來學習!

新聞名稱:如何使用canvas顯示驗證碼
分享URL:http://bm7419.com/article48/iihghp.html

成都網(wǎng)站建設公司_創(chuàng)新互聯(lián),為您提供定制開發(fā)、網(wǎng)站內(nèi)鏈、Google、企業(yè)建站、網(wǎng)站建設關鍵詞優(yōu)化

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉載內(nèi)容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉載,或轉載時需注明來源: 創(chuàng)新互聯(lián)

成都網(wǎng)頁設計公司