vue3 滑动验证组件

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.value
						verifySuccessFun();
					}
				}
			}
			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 = true
				context.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 = 0
					sliderState.value = false
					verifySuccess.value = false
					slideWidth.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>

  • 5
    点赞
  • 19
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 8
    评论
Vue 3 中的图片查看器组件可以使用第三方库来实现,比如 `vue-image-lightbox`。下面是一个简单的示例代码: 首先,安装 `vue-image-lightbox`: ```bash npm install vue-image-lightbox ``` 然后,在你的 Vue 组件中使用 `vue-image-lightbox`: ```vue <template> <div> <img src="path/to/image.jpg" @click="openLightbox" /> <vue-image-lightbox v-if="lightboxOpen" :images="images" :index="currentIndex" @close="closeLightbox" ></vue-image-lightbox> </div> </template> <script> import VueImageLightbox from 'vue-image-lightbox'; import 'vue-image-lightbox/dist/vue-image-lightbox.min.css'; export default { components: { VueImageLightbox, }, data() { return { lightboxOpen: false, currentIndex: 0, images: [ { src: 'path/to/image.jpg', alt: 'Image 1', }, { src: 'path/to/another-image.jpg', alt: 'Image 2', }, // 可以添加更多的图片 ], }; }, methods: { openLightbox() { this.lightboxOpen = true; }, closeLightbox() { this.lightboxOpen = false; }, }, }; </script> ``` 在上面的示例中,我们使用了 `vue-image-lightbox` 组件来实现图片查看器。当用户点击图片时,会触发 `openLightbox` 方法,将 `lightboxOpen` 设置为 `true`,从而显示图片查看器。在 `vue-image-lightbox` 组件中,我们传递了 `images` 属性来指定需要展示的图片数组,`index` 属性来指定当前显示的图片索引。在用户关闭图片查看器时,会触发 `closeLightbox` 方法,将 `lightboxOpen` 设置为 `false`,从而关闭图片查看器。 你可以根据自己的需求,调整图片查看器的样式和功能。希望对你有所帮助!

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 8
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

bdawn

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值