vue3拖动滑块进行验证

组件效果展示


源码

<template><div class="slider-verification" ref="sliderContainer"><div class="slider-left-bg" :style="sliderLeftWidthStyle"></div><div class="prompt-text" :style="verifySuccess ? promptTextStyleSuccess: {}">{{ verifySuccess ? '验证通过' : '向右拖动滑块进行验证' }}</div><div ref="slider" @mousedown="mouseDownHandler($event)":class="{'slider-verify-success':verifySuccess}"class="slider":style="sliderToLeftStyle"></div></div>
</template><script lang="ts">import {defineComponent, ref, onMounted} from 'vue';/*** 组件名称:* 组件描述:*/export default defineComponent({name: 'SliderVerification',components: {},props: {/*** 验证成功提示文字样式*/promptTextStyleSuccess: {type: Object,default: {color: '#ffffff'}},/*** 验证成功需要拖动距离倍数,倍数越大验证成功需要拖动的距离越大*/multiple: {type: Number,default: 2}},setup(props, context) {let sliderState = ref(false)let verifySuccess = ref(false)let beginClientX = ref(0)let maxWidth = ref(0)const slideWidth = ref(0)const mouseMoveHandler = (e) => {if (sliderState.value) {let width = (e.clientX - beginClientX.value) / props.multiple;if (width > 0 && width <= maxWidth.value) {slideWidth.value = width} else if (width > maxWidth.value) {slideWidth.value = maxWidth.valueverifySuccessFun();}}}const moseUpHandler = (e) => {sliderState.value = false;let width = (e.clientX - beginClientX.value) / props.multiple;if (width < maxWidth.value) {slideWidth.value = 0}}const verifySuccessFun = () => {verifySuccess.value = truecontext.emit('statusChange', true)document.getElementsByTagName('html')[0].removeEventListener('mousemove', mouseMoveHandler);document.getElementsByTagName('html')[0].removeEventListener('mouseup', moseUpHandler);slideWidth.value = maxWidth.value}const slider = ref(null)const sliderContainer = ref(null)onMounted(() => {maxWidth.value = sliderContainer.value.offsetWidth - slider.value.offsetWidth;addListener()})const addListener = () => {document.getElementsByTagName('html')[0].addEventListener('mousemove', mouseMoveHandler);document.getElementsByTagName('html')[0].addEventListener('mouseup', moseUpHandler)}return {sliderContainer, slider,beginClientX, // 鼠标按下的位置sliderState,     // 滑块是否可以移动maxWidth,// 滑块验证成功需要移动的最大距离verifySuccess,  // 是否验证成功slideWidth, // 滑块滑过的区域宽度reset() { // 重置addListener()context.emit('statusChange', false)beginClientX.value = 0sliderState.value = falseverifySuccess.value = falseslideWidth.value = 0},mouseDownHandler(e) { // 鼠标在滑块上按下事件if (!this.verifySuccess) {this.sliderState = true;this.beginClientX = e.clientX;}},}},computed: {sliderToLeftStyle() {return {left: this.slideWidth + 'px'}},sliderLeftWidthStyle() {return {width: this.slideWidth + 'px'}}}});
</script>
<style scoped lang="scss">.slider-verification {position: relative;background-color: #055265;width: 100%;height: 100%;line-height: 48px;text-align: center;user-select: none;}.slider {position: absolute;top: 0;width: 42px;height: 100%;cursor: move;background: rgb(0, 157, 177) url("") no-repeat center;background-size: 30px 30px;}.slider-verify-success {background: #8dffc9 url("") no-repeat center;background-size: 30px 30px;}//滑块滑过区域的样式.slider-left-bg {background-color: rgba(0, 235, 255, 0.42);width: 0;height: 100%;}//提示文本样式.prompt-text {position: absolute;top: 0;width: 100%;height: 100%;text-align: center;font-size: 14px;line-height: 1;padding: 13px;color: #ffffff;opacity: 0.7;}
</style>

vue3 滑动验证组件相关推荐

  1. vue3.2+ 滑动验证组件,pc/手机通用,即插即用

    vue3.2+ 滑动验证组件,pc/手机通用,即插即用 一.前言 二.成果展示 三.组件使用 四.vue3.2+ 滑动验证组件 源码 五.最后,点个赞 一.前言 vue已经更新到3.2+,使用了scr ...

  2. 【Vue3】滑动验证组件 | 滑动验证

    前言 滑块验证不只判断是否滑动到尾部,真正的目的是检测用户行为,检测行为是人为.脚本.还是其它. 防止使用脚本大量注册.请求等 .比如发送请求时,判断用户在某个页面停留了多长时间.登录.注册时是否点击 ...

  3. 微信小程序图片验证组件封装

    一.图片滑动验证组件 延迟页面展示或者延缓并发处理.当滑动图片到空缺位置后执行加载或者验证. 二.封装源码 1.wxml <!--遮罩层,弹框图片背景,滑动框图片比例:16:9 1.777777 ...

  4. 滑动验证+短信验证码接入=复制粘贴(Java)

    PC版滑动验证的实现 简介 滑动验证是基于人机识别技术开发的智能验证码产品.用户通过简单的右滑交互,无需思考即可通过验证. 资源引入说明 使用PC版滑动验证码,需要引入以下js资源,为保证服务功能最优 ...

  5. Vue实现图片滑动验证

    Vue实现图片滑动验证 使用vue完成 使用vue完成 实习一个星期小白对工作安排的图片滑动验证分享 1.安装依赖 附上:https://www.npmjs.com/package/vue-monop ...

  6. vue项目中引入阿里云滑动验证

    注册阿里云账号 参照滑动验证demo 滑动验证在vue中使用步骤 1.在vue-cli安装的项目中,index.html页面引入js <html><head><meta ...

  7. PC项目——vue 脚手架中实现阿里云人机滑动验证

    转自๑柯帆๑ 找半天才找到这个可用的 vue 脚手架中实现阿里云人机滑动验证 一.报错问题解决 描述:照官网写的引入方式引入vue报错 AWSC is not define 解决:.html文件引入s ...

  8. Vue3+ Vue-cli (2) 组件篇

    目录 一.全局组件定义和复用性讲解 二.Vue3中的局部组件 三.父子组件的静态和动态传值 四.组件传值时的校验操作 五.组件中重要机制 - 单项数据流 六.Non-props使用技巧 七.组件中通过 ...

  9. Vue3 10多种组件通讯方法

    本文简介 点赞 + 关注 + 收藏 = 学会了 本文讲解 Vue 3.2 组件多种通讯方式的基础用法,并且使用了 单文件组件 <script setup> . 众所周知,Vue.js 中一 ...

最新文章

  1. 传美的投40亿进军卫浴行业
  2. vmware克隆虚拟机
  3. 俄罗斯研发替身机器人,危险工作无需真人
  4. SAP Cloud for Customer前台发送到后台的HTTP请求,遇到错误该怎么分析
  5. USB连接TF卡 SD卡硬件电路
  6. 简单六步上手spring aop,通过各种类型通知,面向切面编程,实现代码解耦(超详细)
  7. Javascript特效:利用给节点增加参数或者闭包实现百度首页换肤
  8. 1.Oracle 安装教程及使用
  9. 与大家分享一些计算机方面的电子书籍
  10. java.lang.reflect.Field常用方法
  11. BLE service, characteristic以及CCCD概念 9
  12. JOB SERVER 负载均衡
  13. [从头读历史] 第249节 易经
  14. Java基础小项目shopping
  15. pythoncad标注教程_CAD 2014二维三维建模渲染标注基础与提升视频教程
  16. HZNU Training 2 for Zhejiang Provincial Collegiate Programming Contest 2019
  17. 数据分析盒马生鲜迭代选址策略!
  18. unity | 竖排显示文字text
  19. 谁在使用Linux?
  20. 【2022年Spring全家桶】学习路线图和资料整理

热门文章

  1. python 爬虫及数据可视化展示
  2. python 白噪声检验-使用python实现时间序列白噪声检验方式
  3. 惊心动魄的开源项目“政变”,堪比宫斗...
  4. Pytorch的grad、backward()、zero_grad()
  5. Html批量统一给汉字注音,HTML5:给汉字加拼音?让我秀给你看
  6. 豆瓣APP上线7.0新版本,从工具到社区的进化之路
  7. C语言—飞机大战小游戏
  8. HDOJ - 2371 矩阵乘法
  9. 3.15曝光智能骚扰产业链,连你月收入也知道!网易专家支招用户如何避免被“鱼肉”
  10. Android事件总线 EventBus3.0用法学习