Vue3使用拼图验证码校验

大祥子
2022-06-14 / 0 评论 / 1,322 阅读 / 正在检测是否收录...
温馨提示:
本文最后更新于2022年06月14日,已超过948天没有更新,若内容或图片失效,请留言反馈。

1、在Vue3中使用图片拼图验证码npm i vue3-slide-verify详见
2、代码中使用(未封装,有需要可以封装)

<div>
  <slide-verify ref="block" slider-text="向右滑动->" :accuracy="1" @again="onAgain" @success="onSuccess"
    @fail="onFail" @refresh="onRefresh"></slide-verify>
  <button class="btn" @click="handleClick">在父组件可以点我刷新哦</button>
  <div>{{ msg }}</div>
</div>

<script>
import { toRefs, reactive, ref } from 'vue'
// 局部注册组件,需要单独引用组件样式
// 只提供局部引用的方式,不再采用插件形式,方便按需加载,减少主包大小
import SlideVerify from "vue3-slide-verify";
import "vue3-slide-verify/dist/style.css";
export default {
  components: { SlideVerify },
  setup(props, { emit }) {
    const msg = ref("");
    const block = ref();
    // 传参
    const state = reactive({
    })
    const onAgain = () => {
      msg.value = "检测到非人为操作的哦! try again";
      // 刷新
      block.value?.refresh();
    }

    const onSuccess = (times) => {
      msg.value = `login success, 耗时${(times / 1000).toFixed(1)}s`;
    }

    const onFail = () => {
      msg.value = "验证不通过";
    }

    const onRefresh = () => {
      msg.value = "点击了刷新小图标";
    }

    const handleClick = () => {
      // 刷新
      block.value?.refresh();
      msg.value = "";
    }
    return {
      block,
      msg,
      onAgain,
      onSuccess,
      onFail,
      onRefresh,
      handleClick,
    }
  }
}
</script>

3、其他备注

argument

ParamTypeDescribeVersion
lNumberblock length
rNumberblock circle radius
wNumbercanvas width
hNumbercanvas height
sliderTextStringSlide filled right
imgsArraypicture array 背景图数组,默认值 []
accuracyNumber滑动验证的误差范围,默认值 5
showBoolean是否显示刷新按钮,默认值 true

callBack

EventTypeDescribeVersion
successFunctionsuccess callback返回时间参数,单位为毫秒
failFunctionfail callback
refreshFunction点击刷新按钮后的回调函数
againFunction检测到非人为操作滑动时触发的回调函数
52

评论 (0)

取消