1.这里针对滑块验证给了一个封装的组件verifition,使用直接可以调用
2.组件目录
3.每个文件的内容
3.1 Api文件中只有一个index.js文件,用来存放获取滑块和校验滑块结果的api
import request from '@/router/axios'
export function reqGet ( data ) { return request ( { url : '/code' , method : 'get' , data} )
}
export function reqCheck ( data ) { return request ( { url : '/code/check' , method : 'post' , params : data} )
}
3.2 utils文件夹中反了一些工具函数为校验提供支持,包含三个文件:ase.js、axios.js、util.js,不涉及任何组件的引用,可放心使用
import CryptoJS from 'crypto-js'
export function aesEncrypt ( word, keyWord= "XwKsGlMcdPMEhR1B" ) { var key = CryptoJS. enc. Utf8. parse ( keyWord) ; var srcs = CryptoJS. enc. Utf8. parse ( word) ; var encrypted = CryptoJS. AES . encrypt ( srcs, key, { mode : CryptoJS. mode. ECB , padding : CryptoJS. pad. Pkcs7} ) ; return encrypted. toString ( ) ;
}
import axios from 'axios' ; axios. defaults. baseURL = process. env. BASE_API ; const service = axios. create ( { timeout : 40000 , headers : { 'X-Requested-With' : 'XMLHttpRequest' , 'Content-Type' : 'application/json; charset=UTF-8' } ,
} )
service. interceptors. request. use ( config => { return config} , error => { Promise. reject ( error) }
)
service. interceptors. response. use ( response => { const res = response. data; return res} , error => { }
)
export default service
export function resetSize ( vm ) { var img_width, img_height, bar_width, bar_height; var parentWidth = vm. $el. parentNode. offsetWidth || window. offsetWidthvar parentHeight = vm. $el. parentNode. offsetHeight || window. offsetHeightif ( vm. imgSize. width. indexOf ( '%' ) != - 1 ) { img_width = parseInt ( this . imgSize. width) / 100 * parentWidth + 'px' } else { img_width = this . imgSize. width; } if ( vm. imgSize. height. indexOf ( '%' ) != - 1 ) { img_height = parseInt ( this . imgSize. height) / 100 * parentHeight + 'px' } else { img_height = this . imgSize. height} if ( vm. barSize. width. indexOf ( '%' ) != - 1 ) { bar_width = parseInt ( this . barSize. width) / 100 * parentWidth + 'px' } else { bar_width = this . barSize. width} if ( vm. barSize. height. indexOf ( '%' ) != - 1 ) { bar_height = parseInt ( this . barSize. height) / 100 * parentHeight + 'px' } else { bar_height = this . barSize. height} return { imgWidth : img_width, imgHeight : img_height, barWidth : bar_width, barHeight : bar_height}
} export const _code_chars = [ 1 , 2 , 3 , 4 , 5 , 6 , 7 , 8 , 9 , 'a' , 'b' , 'c' , 'd' , 'e' , 'f' , 'g' , 'h' , 'i' , 'j' , 'k' , 'l' , 'm' , 'n' , 'o' , 'p' , 'q' , 'r' , 's' , 't' , 'u' , 'v' , 'w' , 'x' , 'y' , 'z' , 'A' , 'B' , 'C' , 'D' , 'E' , 'F' , 'G' , 'H' , 'I' , 'J' , 'K' , 'L' , 'M' , 'N' , 'O' , 'P' , 'Q' , 'R' , 'S' , 'T' , 'U' , 'V' , 'W' , 'X' , 'Y' , 'Z' ]
export const _code_color1 = [ '#fffff0' , '#f0ffff' , '#f0fff0' , '#fff0f0' ]
export const _code_color2 = [ '#FF0033' , '#006699' , '#993366' , '#FF9900' , '#66CC66' , '#FF33CC' ]
3.3Verify文件夹中放的是关键的组件内容,包含两个文件:VerifyPoints.vue,VerifySlide.vue
< template> < div style= "position: relative" > < div class = "verify-img-out" > < div class = "verify-img-panel" : style= "{ width : setSize. imgWidth, height : setSize. imgHeight, 'background-size' : setSize. imgWidth + ' ' + setSize. imgHeight, 'margin-bottom' : vSpace + 'px' , } "> < div class = "verify-refresh" style= "z-index: 3" @click= "refresh" v- show= "showRefresh" > < i class = "iconfont icon-refresh" > < / i> < / div> < img : src= "'data:image/png;base64,' + pointBackImgBase" ref= "canvas" altstyle= "width: 100%; height: 100%; display: block" @click= "bindingClick ? canvasClick($event) : undefined" / > < div v- for = "(tempPoint, index) in tempPoints" : key= "index" class = "point-area" : style= "{ 'background-color' : '#1abd6c' , color : '#fff' , 'z-index' : 9999 , width : '20px' , height : '20px' , 'text-align' : 'center' , 'line-height' : '20px' , 'border-radius' : '50%' , position : 'absolute' , top : parseInt ( tempPoint. y - 10 ) + 'px' , left : parseInt ( tempPoint. x - 10 ) + 'px' , } "> { { index + 1 } } < / div> < / div> < / div> < ! -- 'height' : this . barSize. height, -- > < div class = "verify-bar-area" : style= "{ width : setSize. imgWidth, color : this . barAreaColor, 'border-color' : this . barAreaBorderColor, 'line-height' : this . barSize. height, } "> < span class = "verify-msg" > { { text } } < / span> < / div> < / div>
< / template>
< script type= "text/babel" >
import { resetSize, _code_chars, _code_color1, _code_color2,
} from "./../utils/util" ;
import { aesEncrypt } from "./../utils/ase" ;
import { reqGet, reqCheck } from "./../api/index" ; export default { name : "VerifyPoints" , props : { mode : { type : String, default : "fixed" , } , captchaType : { type : String, } , vSpace : { type : Number, default : 5 , } , imgSize : { type : Object, default ( ) { return { width : "310px" , height : "155px" , } ; } , } , barSize : { type : Object, default ( ) { return { width : "310px" , height : "40px" , } ; } , } , } , data ( ) { return { secretKey : "" , checkNum : 3 , fontPos : [ ] , checkPosArr : [ ] , num : 1 , pointBackImgBase : "" , poinTextList : [ ] , backToken : "" , setSize : { imgHeight : 0 , imgWidth : 0 , barHeight : 0 , barWidth : 0 , } , tempPoints : [ ] , text : "" , barAreaColor : undefined , barAreaBorderColor : undefined , showRefresh : true , bindingClick : true , } ; } , computed : { resetSize ( ) { return resetSize; } , } , methods : { init ( ) { this . fontPos. splice ( 0 , this . fontPos. length) ; this . checkPosArr. splice ( 0 , this . checkPosArr. length) ; this . num = 1 ; this . getPictrue ( ) ; this . $nextTick ( ( ) => { this . setSize = this . resetSize ( this ) ; this . $parent. $emit ( "ready" , this ) ; } ) ; } , canvasClick ( e ) { this . checkPosArr. push ( this . getMousePos ( this . $refs. canvas, e) ) ; if ( this . num == this . checkNum) { this . num = this . createPoint ( this . getMousePos ( this . $refs. canvas, e) ) ; this . checkPosArr = this . pointTransfrom ( this . checkPosArr, this . setSize) ; setTimeout ( ( ) => { var captchaVerification = this . secretKey? aesEncrypt ( this . backToken + "---" + JSON . stringify ( this . checkPosArr) , this . secretKey) : this . backToken + "---" + JSON . stringify ( this . checkPosArr) ; let data = { captchaType : this . captchaType, pointJson : this . secretKey? aesEncrypt ( JSON . stringify ( this . checkPosArr) , this . secretKey) : JSON . stringify ( this . checkPosArr) , token : this . backToken, } ; reqCheck ( data) . then ( ( response ) => { let res = response. data. data; if ( res. repCode == "0000" ) { this . barAreaColor = "#4cae4c" ; this . barAreaBorderColor = "#5cb85c" ; this . text = "验证成功" ; this . bindingClick = false ; if ( this . mode == "pop" ) { setTimeout ( ( ) => { this . $parent. clickShow = false ; this . refresh ( ) ; } , 1500 ) ; } this . $parent. $emit ( "success" , { captchaVerification } ) ; } else { this . $parent. $emit ( "error" , this ) ; this . barAreaColor = "#d9534f" ; this . barAreaBorderColor = "#d9534f" ; this . text = "验证失败" ; setTimeout ( ( ) => { this . refresh ( ) ; } , 700 ) ; } } ) ; } , 400 ) ; } if ( this . num < this . checkNum) { this . num = this . createPoint ( this . getMousePos ( this . $refs. canvas, e) ) ; } } , getMousePos : function ( obj, e ) { var x = e. offsetX; var y = e. offsetY; return { x, y } ; } , createPoint : function ( pos ) { this . tempPoints. push ( Object. assign ( { } , pos) ) ; return ++ this . num; } , refresh : function ( ) { this . tempPoints. splice ( 0 , this . tempPoints. length) ; this . barAreaColor = "#000" ; this . barAreaBorderColor = "#ddd" ; this . bindingClick = true ; this . fontPos. splice ( 0 , this . fontPos. length) ; this . checkPosArr. splice ( 0 , this . checkPosArr. length) ; this . num = 1 ; this . getPictrue ( ) ; this . text = "验证失败" ; this . showRefresh = true ; } , getPictrue ( ) { let data = { captchaType : this . captchaType, } ; reqGet ( data) . then ( ( response ) => { let res = response. data. data; if ( res. repCode == "0000" ) { this . pointBackImgBase = res. repData. originalImageBase64; this . backToken = res. repData. token; this . secretKey = res. repData. secretKey; this . poinTextList = res. repData. wordList; this . text = "请依次点击【" + this . poinTextList. join ( "," ) + "】" ; } else { this . text = res. repMsg; } } ) ; } , pointTransfrom ( pointArr, imgSize ) { var newPointArr = pointArr. map ( ( p ) => { let x = Math. round ( ( 310 * p. x) / parseInt ( imgSize. imgWidth) ) ; let y = Math. round ( ( 155 * p. y) / parseInt ( imgSize. imgHeight) ) ; return { x, y } ; } ) ; return newPointArr; } , } , watch : { type : { immediate : true , handler ( ) { this . init ( ) ; } , } , } , mounted ( ) { this . $el. onselectstart = function ( ) { return false ; } ; } ,
} ;
< / script>
< template> < div style= "position: relative" > < div v- if = "type === '2'" class = "verify-img-out" : style= "{ height: parseInt(setSize.imgHeight) + vSpace + 'px' }" > < div class = "verify-img-panel" : style= "{ width: setSize.imgWidth, height: setSize.imgHeight }" > < img : src= "'data:image/png;base64,' + backImgBase" alt style= "width: 100%; height: 100%; display: block" / > < div class = "verify-refresh" @click= "refresh" v- show= "showRefresh" > < i class = "iconfont icon-refresh" > < / i> < / div> < transition name= "tips" > < span class = "verify-tips" v- if = "tipWords" : class = "passFlag ? 'suc-bg' : 'err-bg'" > { { tipWords } } < / span> < / transition> < / div> < / div> < ! -- 公共部分 -- > < div class = "verify-bar-area" : style= "{ width : setSize. imgWidth, height : barSize. height, 'line-height' : barSize. height, } "> < span class = "verify-msg" v- text= "text" > < / span> < div class = "verify-left-bar" : style= "{ width : leftBarWidth !== undefined ? leftBarWidth : barSize. height, height : barSize. height, 'border-color' : leftBarBorderColor, transaction : transitionWidth, } "> < span class = "verify-msg" v- text= "finishText" > < / span> < div class = "verify-move-block" @touchstart= "start" @mousedown= "start" : style= "{ width : barSize. height, height : barSize. height, 'background-color' : moveBlockBackgroundColor, left : moveBlockLeft, transition : transitionLeft, } "> < i : class = "['verify-icon iconfont', iconClass]" : style= "{ color: iconColor }" > < / i> < div v- if = "type === '2'" class = "verify-sub-block" : style= "{ width : Math. floor ( ( parseInt ( setSize. imgWidth) * 47 ) / 310 ) + 'px' , height : setSize. imgHeight, top : '-' + ( parseInt ( setSize. imgHeight) + vSpace) + 'px' , 'background-size' : setSize. imgWidth + ' ' + setSize. imgHeight, } "> < img : src= "'data:image/png;base64,' + blockBackImgBase" altstyle= "width: 100%; height: 100%; display: block" / > < / div> < / div> < / div> < / div> < / div>
< / template>
< script type= "text/babel" >
import { aesEncrypt } from "./../utils/ase" ;
import { resetSize } from "./../utils/util" ;
import { reqGet, reqCheck } from "./../api/index" ;
export default { name : "VerifySlide" , props : { captchaType : { type : String, } , type : { type : String, default : "1" , } , mode : { type : String, default : "fixed" , } , vSpace : { type : Number, default : 5 , } , explain : { type : String, default : "向右滑动完成验证" , } , imgSize : { type : Object, default ( ) { return { width : "310px" , height : "155px" , } ; } , } , blockSize : { type : Object, default ( ) { return { width : "50px" , height : "50px" , } ; } , } , barSize : { type : Object, default ( ) { return { width : "310px" , height : "40px" , } ; } , } , } , data ( ) { return { secretKey : "" , passFlag : "" , backImgBase : "" , blockBackImgBase : "" , backToken : "" , startMoveTime : "" , endMovetime : "" , tipsBackColor : "" , tipWords : "" , text : "" , finishText : "" , setSize : { imgHeight : 0 , imgWidth : 0 , barHeight : 0 , barWidth : 0 , } , top : 0 , left : 0 , moveBlockLeft : undefined , leftBarWidth : undefined , moveBlockBackgroundColor : undefined , leftBarBorderColor : "#ddd" , iconColor : undefined , iconClass : "icon-right" , status : false , isEnd : false , showRefresh : true , transitionLeft : "" , transitionWidth : "" , } ; } , computed : { barArea ( ) { return this . $el. querySelector ( ".verify-bar-area" ) ; } , resetSize ( ) { return resetSize; } , } , methods : { init ( ) { this . text = this . explain; this . getPictrue ( ) ; this . $nextTick ( ( ) => { let setSize = this . resetSize ( this ) ; for ( let key in setSize) { this . $set ( this . setSize, key, setSize[ key] ) ; } this . $parent. $emit ( "ready" , this ) ; } ) ; var _this = this ; window. removeEventListener ( "touchmove" , function ( e ) { _this. move ( e) ; } ) ; window. removeEventListener ( "mousemove" , function ( e ) { _this. move ( e) ; } ) ; window. removeEventListener ( "touchend" , function ( ) { _this. end ( ) ; } ) ; window. removeEventListener ( "mouseup" , function ( ) { _this. end ( ) ; } ) ; window. addEventListener ( "touchmove" , function ( e ) { _this. move ( e) ; } ) ; window. addEventListener ( "mousemove" , function ( e ) { _this. move ( e) ; } ) ; window. addEventListener ( "touchend" , function ( ) { _this. end ( ) ; } ) ; window. addEventListener ( "mouseup" , function ( ) { _this. end ( ) ; } ) ; } , start : function ( e ) { e = e || window. event; if ( ! e. touches) { var x = e. clientX; } else { var x = e. touches[ 0 ] . pageX; } this . startLeft = Math. floor ( x - this . barArea. getBoundingClientRect ( ) . left) ; this . startMoveTime = + new Date ( ) ; if ( this . isEnd == false ) { this . text = "" ; this . moveBlockBackgroundColor = "#337ab7" ; this . leftBarBorderColor = "#337AB7" ; this . iconColor = "#fff" ; e. stopPropagation ( ) ; this . status = true ; } } , move : function ( e ) { e = e || window. event; if ( this . status && this . isEnd == false ) { if ( ! e. touches) { var x = e. clientX; } else { var x = e. touches[ 0 ] . pageX; } var bar_area_left = this . barArea. getBoundingClientRect ( ) . left; var move_block_left = x - bar_area_left; if ( move_block_left >= this . barArea. offsetWidth - parseInt ( parseInt ( this . blockSize. width) / 2 ) - 2 ) { move_block_left = this . barArea. offsetWidth - parseInt ( parseInt ( this . blockSize. width) / 2 ) - 2 ; } if ( move_block_left <= 0 ) { move_block_left = parseInt ( parseInt ( this . blockSize. width) / 2 ) ; } this . moveBlockLeft = move_block_left - this . startLeft + "px" ; this . leftBarWidth = move_block_left - this . startLeft + "px" ; } } , end : function ( ) { this . endMovetime = + new Date ( ) ; var _this = this ; if ( this . status && this . isEnd == false ) { var moveLeftDistance = parseInt ( ( this . moveBlockLeft || "" ) . replace ( "px" , "" ) ) ; moveLeftDistance = ( moveLeftDistance * 310 ) / parseInt ( this . setSize. imgWidth) ; let data = { captchaType : this . captchaType, pointJson : this . secretKey? aesEncrypt ( JSON . stringify ( { x : moveLeftDistance, y : 5.0 } ) , this . secretKey) : JSON . stringify ( { x : moveLeftDistance, y : 5.0 } ) , token : this . backToken, } ; reqCheck ( data) . then ( ( response ) => { let res = response. data. data; if ( res. repCode == "0000" ) { this . moveBlockBackgroundColor = "#5cb85c" ; this . leftBarBorderColor = "#5cb85c" ; this . iconColor = "#fff" ; this . iconClass = "icon-check" ; this . showRefresh = false ; this . isEnd = true ; if ( this . mode == "pop" ) { setTimeout ( ( ) => { this . $parent. clickShow = false ; this . refresh ( ) ; } , 1500 ) ; } this . passFlag = true ; this . tipWords = ` ${ ( ( this . endMovetime - this . startMoveTime) / 1000 ) . toFixed ( 2 ) } s验证成功 ` ; var captchaVerification = this . secretKey? aesEncrypt ( this . backToken + "---" + JSON . stringify ( { x : moveLeftDistance, y : 5.0 } ) , this . secretKey) : this . backToken + "---" + JSON . stringify ( { x : moveLeftDistance, y : 5.0 } ) ; setTimeout ( ( ) => { this . tipWords = "" ; this . $parent. closeBox ( ) ; this . $parent. $emit ( "success" , { captchaVerification } ) ; } , 1000 ) ; } else { this . moveBlockBackgroundColor = "#d9534f" ; this . leftBarBorderColor = "#d9534f" ; this . iconColor = "#fff" ; this . iconClass = "icon-close" ; this . passFlag = false ; setTimeout ( function ( ) { _this. refresh ( ) ; } , 1000 ) ; this . $parent. $emit ( "error" , this ) ; this . tipWords = "验证失败" ; setTimeout ( ( ) => { this . tipWords = "" ; } , 1000 ) ; } } ) ; this . status = false ; } } , refresh : function ( ) { this . showRefresh = true ; this . finishText = "" ; this . transitionLeft = "left .3s" ; this . moveBlockLeft = 0 ; this . leftBarWidth = undefined ; this . transitionWidth = "width .3s" ; this . leftBarBorderColor = "#ddd" ; this . moveBlockBackgroundColor = "#fff" ; this . iconColor = "#000" ; this . iconClass = "icon-right" ; this . isEnd = false ; this . getPictrue ( ) ; setTimeout ( ( ) => { this . transitionWidth = "" ; this . transitionLeft = "" ; this . text = this . explain; } , 300 ) ; } , getPictrue ( ) { let data = { captchaType : this . captchaType, } ; reqGet ( data) . then ( ( response ) => { let res = response. data. data; if ( res. repCode == "0000" ) { this . backImgBase = res. repData. originalImageBase64; this . blockBackImgBase = res. repData. jigsawImageBase64; this . backToken = res. repData. token; this . secretKey = res. repData. secretKey; } else { this . tipWords = res. repMsg; } } ) ; } , } , watch : { type : { immediate : true , handler ( ) { this . init ( ) ; } , } , } , mounted ( ) { this . $el. onselectstart = function ( ) { return false ; } ; } ,
} ;
< / script>
3.4父组件内容,使用时调用show方法即可
< template> < div : class = "mode == 'pop' ? 'mask' : ''" v- show= "showBox" > < div : class = "mode == 'pop' ? 'verifybox' : ''" : style= "{ 'max-width': parseInt(imgSize.width) + 30 + 'px' }" > < div class = "verifybox-top" v- if = "mode == 'pop'" > 请完成安全验证< span class = "verifybox-close" @click= "closeBox" > < i class = "iconfont icon-close" > < / i> < / span> < / div> < div class = "verifybox-bottom" : style= "{ padding: mode == 'pop' ? '15px' : '0' }" > < ! -- 验证码容器 -- > < components v- if = "componentType" : is= "componentType" : captchaType= "captchaType" : type= "verifyType" : figure= "figure" : arith= "arith" : mode= "mode" : vSpace= "vSpace" : explain= "explain" : imgSize= "imgSize" : blockSize= "blockSize" : barSize= "barSize" ref= "instance" > < / components> < / div> < / div> < / div>
< / template>
< script type= "text/babel" >
import VerifySlide from "./Verify/VerifySlide" ;
import VerifyPoints from "./Verify/VerifyPoints" ; export default { name : "Vue2Verify" , props : { locale : { require : false , type : String, default ( ) { if ( navigator. language) { var language = navigator. language; } else { var language = navigator. browserLanguage; } return language; } , } , captchaType : { type : String, required : true , } , figure : { type : Number, } , arith : { type : Number, } , mode : { type : String, default : "pop" , } , vSpace : { type : Number, } , explain : { type : String, } , imgSize : { type : Object, default ( ) { return { width : "310px" , height : "155px" , } ; } , } , blockSize : { type : Object, } , barSize : { type : Object, } , } , data ( ) { return { clickShow : false , verifyType : undefined , componentType : undefined , } ; } , methods : { i18n ( text ) { if ( this . $t) { return this . $t ( text) ; } else { let i18n = this . $options. i18n. messages[ this . locale] || this . $options. i18n. messages[ "en-US" ] ; return i18n[ text] ; } } , refresh ( ) { if ( this . instance. refresh) { this . instance. refresh ( ) ; } } , closeBox ( ) { this . clickShow = false ; this . refresh ( ) ; } , show ( ) { if ( this . mode == "pop" ) { this . clickShow = true ; } } , } , computed : { instance ( ) { return this . $refs. instance || { } ; } , showBox ( ) { if ( this . mode == "pop" ) { return this . clickShow; } else { return true ; } } , } , watch : { captchaType : { immediate : true , handler ( captchaType ) { switch ( captchaType. toString ( ) ) { case "blockPuzzle" : this . verifyType = "2" ; this . componentType = "VerifySlide" ; break ; case "clickWord" : this . verifyType = "" ; this . componentType = "VerifyPoints" ; break ; } } , } , } , components : { VerifySlide, VerifyPoints, } ,
} ;
< / script>
< style>
. verifybox { position : relative; box- sizing: border- box; border- radius: 18px; border : 1px solid #e4e7eb; background- color: #fff; box- shadow: 0 0 10px rgba ( 0 , 0 , 0 , 0.3 ) ; left : 50 % ; top : 30 % ; transform : translate ( - 50 % , - 60 % ) ;
} . verifybox- top { padding : 0 15px; height : 50px; line- height: 50px; text- align: left; font- size: 16px; color : #45494c; border- bottom: 1px solid #e4e7eb; box- sizing: border- box;
} . verifybox- bottom { padding : 15px; box- sizing: border- box;
} . verifybox- close { position : absolute; top : 13px; right : 9px; width : 24px; height : 24px; text- align: center; cursor : pointer;
} . mask { position : fixed; top : 0 ; left : 0 ; z- index: 1001 ; width : 100 % ; height : 100vh; transition : all 0 . 5s;
} . verify- tips { position : absolute; left : 0px; bottom : 0px; width : 100 % ; height : 30px; line- height: 30px; color : #fff;
} . suc- bg { background- color: rgba ( 92 , 184 , 92 , 0.5 ) ; filter : progid: DXImageTransform. Microsoft. gradient ( startcolorstr= #7f5CB85C, endcolorstr= #7f5CB85C) ;
} . err- bg { background- color: rgba ( 217 , 83 , 79 , 0.5 ) ; filter : progid: DXImageTransform. Microsoft. gradient ( startcolorstr= #7fD9534F, endcolorstr= #7fD9534F) ;
} . tips- enter,
. tips- leave- to { bottom : - 30px;
} . tips- enter- active,
. tips- leave- active { transition : bottom 0 . 5s;
}
. verify- code { font- size: 20px; text- align: center; cursor : pointer; margin- bottom: 5px; border : 1px solid #ddd;
} . cerify- code- panel { height : 100 % ; overflow : hidden;
} . verify- code- area { float : left;
} . verify- input- area { float : left; width : 60 % ; padding- right: 10px;
} . verify- change- area { line- height: 30px; float : left;
} . varify- input- code { display : inline- block; width : 100 % ; height : 25px;
} . verify- change- code { color : #337ab7; cursor : pointer;
} . verify- btn { width : 200px; height : 30px; background- color: #337ab7; color : #ffffff; border : none; margin- top: 10px;
}
. verify- bar- area { position : relative; background : #ffffff; text- align: center; - webkit- box- sizing: content- box; - moz- box- sizing: content- box; box- sizing: content- box; border : 1px solid #ddd; - webkit- border- radius: 4px;
} . verify- bar- area . verify- move- block { position : absolute; top : 0px; left : 0 ; background : #fff; cursor : pointer; - webkit- box- sizing: content- box; - moz- box- sizing: content- box; box- sizing: content- box; box- shadow: 0 0 2px #888888 ; - webkit- border- radius: 1px;
} . verify- bar- area . verify- move- block: hover { background- color: #337ab7; color : #ffffff;
} . verify- bar- area . verify- left- bar { position : absolute; top : - 1px; left : - 1px; background : #f0fff0; cursor : pointer; - webkit- box- sizing: content- box; - moz- box- sizing: content- box; box- sizing: content- box; border : 1px solid #ddd;
} . verify- img- panel { margin : 0 ; - webkit- box- sizing: content- box; - moz- box- sizing: content- box; box- sizing: content- box; border- top: 1px solid #ddd; border- bottom: 1px solid #ddd; border- radius: 3px; position : relative;
} . verify- img- panel . verify- refresh { width : 25px; height : 25px; text- align: center; padding : 5px; cursor : pointer; position : absolute; top : 0 ; right : 0 ; z- index: 2 ;
} . verify- img- panel . icon- refresh { font- size: 20px; color : #fff;
} . verify- img- panel . verify- gap { background- color: #fff; position : relative; z- index: 2 ; border : 1px solid #fff;
} . verify- bar- area . verify- move- block . verify- sub- block { position : absolute; text- align: center; z- index: 3 ;
} . verify- bar- area . verify- move- block . verify- icon { font- size: 18px;
} . verify- bar- area . verify- msg { z- index: 3 ;
}
. iconfont { font- family: "iconfont" ! important; font- size: 16px; font- style: normal; - webkit- font- smoothing: antialiased; - moz- osx- font- smoothing: grayscale;
} . icon- check: before { content : " " ; display : block; width : 16px; height : 16px; position : absolute; margin : auto; left : 0 ; right : 0 ; top : 0 ; bottom : 0 ; z- index: 9999 ; background- image: url ( "" ) ; background- size: contain;
} . icon- close: before { content : " " ; display : block; width : 16px; height : 16px; position : absolute; margin : auto; left : 0 ; right : 0 ; top : 0 ; bottom : 0 ; z- index: 9999 ; background- image: url ( "" ) ; background- size: contain;
} . icon- right: before { content : " " ; display : block; width : 16px; height : 16px; position : absolute; margin : auto; left : 0 ; right : 0 ; top : 0 ; bottom : 0 ; background- size: cover; z- index: 9999 ; background- image: url ( "" ) ; background- size: contain;
} . icon- refresh: before { content : " " ; display : block; width : 16px; height : 16px; position : absolute; margin : auto; left : 0 ; right : 0 ; top : 0 ; bottom : 0 ; z- index: 9999 ; background- image: url ( "" ) ; background- size: contain;
}
< / style>
4.组件的使用
< Verify @success= "verifySuccess" : mode= "'pop'" : captchaType= "'blockPuzzle'" : imgSize= "{ width: '330px', height: '155px' }" ref= "verify" / >
this . $refs. verify. show ( )
verifySuccess ( paramas ) {
}