广告
返回顶部
首页 > 资讯 > 前端开发 > JavaScript >vue3实现旋转图片验证
  • 1250
分享到

vue3实现旋转图片验证

2024-04-02 19:04:59 1250人浏览 安东尼
摘要

本文实例为大家分享了vue3实现旋转图片验证的具体代码,供大家参考,具体内容如下 一、前言 一个突发奇想的创作。 二、代码 <template>   <el-dia

本文实例为大家分享了vue3实现旋转图片验证的具体代码,供大家参考,具体内容如下

一、前言

一个突发奇想的创作。

二、代码

<template>
  <el-dialog
      v-model="dialogVisible"
      width="15%"
      :before-close="handleClose">
    <el-image :src="imageUrl" :style="xuanzhuan" class="w-full flex justify-center rounded-full overflow-hidden">
      <template #error>
        <div class="image-slot">
          <i class="el-icon-picture-outline text-3xl"></i>
        </div>
      </template>
    </el-image>
    <template #footer>
      <div class="w-full mx-1 my-1 h-8 bg-gray-300 relative">
        <i @mousedown="rangeMove" :style="leftnum" class="el-icon-d-arrow-right h-8 w-8 bg-white border absolute top-0 bottom-0 flex justify-center items-center cursor-pointer select-none"></i>
      </div>
      <div class="w-full flex justify-evenly">
        <el-button @click="chongzhi()">重置</el-button>
        <el-button type="primary" @click="tijiao()">确定</el-button>
      </div>
    </template>
  </el-dialog>

</template>

<script lang="ts">
import {computed, defineComponent, ref} from "Vue";
export default defineComponent({
  name:"xuanzhuan",
  setup(prop,content) {
    // 左侧距离和移动距离
    const disX = ref(0)
    const leftnum = computed(()=>{
      return `left: ${disX.value}px`
    })
    // 角度和 旋转角度
    const jiaodu = ref(0)
    const xuanzhuan = computed(()=>{
      return `transfORM:rotate(${jiaodu.value}deg);`
    })

    const dialogVisible = ref(false)
    const imageUrl = ref("/file/imgs/upload/202211/13/yhnycqkgzut.jpg")
    function getimage(){
      console.log("向后台获取图片")
    }
    function init(){
      dialogVisible.value = true
      getimage()
    }
    function handleClose(){
      jiaodu.value = 0
      disX.value = 0
      imageUrl.value = ""
      dialogVisible.value = false
    }
    function rangeMove(e:any){
      let ele = e.target;
      let startX = e.clientX - disX.value;
      let eleWidth = ele.offsetWidth;
      let parentWidth =  ele.parentElement.offsetWidth;
      let MaxX = parentWidth - eleWidth;
      document.onmousemove = (e)=>{
        let endX = e.clientX;
        disX.value = endX - startX;
        if(disX.value<=0){
          disX.value = 0;
        }else if(disX.value>=MaxX){   //减去滑块的宽度,体验效果更好
          disX.value = MaxX;
        }

        // 计算滑动距离与全长的比例
        const bili = disX.value / (MaxX-eleWidth)
        // 用比例乘以360度,就是旋转角度
        jiaodu.value = bili * 360
      }
      document.onmouseup=()=>{
        document.onmousemove = null;
        document.onmouseup = null;
      }
    }
    // 逐步减少,看上去好看点
    function jianshao(disbuchang:number,jiaobubuchang:number){
      jiaodu.value = jiaodu.value - jiaobubuchang
      disX.value = disX.value - disbuchang
      if(disX.value <=0 ){
        jiaodu.value = 0
        disX.value = 0
      }
    }
    // 点击重置,使用异步方法,逐步回到原点
    function chongzhi(){
      const disbuchang = 50
      const jiaobubuchang = disbuchang/disX.value * jiaodu.value
      const mandian = setInterval(()=>{
        if(disX.value == 0){
          clearInterval(mandian)
        }else{
          jianshao(disbuchang,jiaobubuchang)
        }
      },10)
    }
    // 点击确定
    function tijiao(){
      if(disX.value == 0){
        return
      }
      console.log("后端验证成功")
      // 成功后,触发父组件方法。
      content.emit("get")
    }
    return {
      handleClose,
      imageUrl,
      dialogVisible,
      init,
      rangeMove,
      leftnum,
      xuanzhuan,
      chongzhi,
      tijiao,
    }
  },
  components:{},
})
</script>

<style scoped>

</style>

CSS用的是tailwindcss。

三.使用方法

<xuanzhuan ref="myxuanzhuan" @get="chengGong"></xuanzhuan>

setup(prop,content) {
    const myxuanzhuan:any = ref(null)
    function ceshi(){
      myxuanzhuan.value.init()
    }
    function chenggong(){
        console.log("成功的回调")
    }
}

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持编程网。

--结束END--

本文标题: vue3实现旋转图片验证

本文链接: https://www.lsjlt.com/news/146973.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • vue3实现旋转图片验证
    本文实例为大家分享了vue3实现旋转图片验证的具体代码,供大家参考,具体内容如下 一、前言 一个突发奇想的创作。 二、代码 <template>   <el-dia...
    99+
    2022-11-13
  • vue3怎么实现旋转图片验证
    这篇“vue3怎么实现旋转图片验证”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“vue3怎么实现旋转图片验证”文章吧。一、前...
    99+
    2023-06-30
  • PHP如何实现旋转图片验证
    这篇文章主要介绍了PHP如何实现旋转图片验证的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇PHP如何实现旋转图片验证文章都会有所收获,下面我们一起来看看吧。安装composer require&nbs...
    99+
    2023-07-04
  • 如何实现HTML图片旋转
    小编给大家分享一下如何实现HTML图片旋转,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!实现HTML图片旋转,HTML5+CSS...
    99+
    2022-10-19
  • CSS3实现图片放大旋转
    知识点:    css3动画    transition     @-webkit-keyframes rotation{ from {-webkit-transform: rotate(0deg);} to {-webkit-transf...
    99+
    2023-01-31
    图片
  • css怎么实现图片的旋转
    这篇文章主要介绍了css怎么实现图片的旋转,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。   1、构建图像轮播框架   首先是HTML。...
    99+
    2022-10-19
  • Htlm如何实现图片3D旋转
    这篇文章主要介绍了Htlm如何实现图片3D旋转的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇Htlm如何实现图片3D旋转文章都会有所收获,下面我们一起来看看吧。animatio...
    99+
    2022-10-19
  • Css3怎么实现图片空间旋转
    这篇文章主要介绍了Css3怎么实现图片空间旋转的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇Css3怎么实现图片空间旋转文章都会有所收获,下面我们一起来看看吧。transfor...
    99+
    2022-10-19
  • jquery怎么实现查看图片旋转
    在前端开发中,显示和浏览图片是一个常见的需求。有时候我们需要对图片进行旋转,来达到更好的显示效果。在此情况下,我们可以使用 jQuery 库来轻松地实现图片旋转的功能。下面将详细介绍如何使用 jQuery 实现查看图片旋转。一、准备工作首先...
    99+
    2023-05-14
  • jquery如何实现查看图片旋转
    这篇“jquery如何实现查看图片旋转”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“jquery如何实现查看图片旋转”文章吧...
    99+
    2023-07-06
  • java实现图片验证码
    本文实例为大家分享了java实现图片验证码的具体代码,供大家参考,具体内容如下 目的: 1) 验证操作者是否是人 2) 防止表单重复提交 生成验证码的要点: 1) 使用java代码生...
    99+
    2022-11-13
  • iOS实现音乐播放器图片旋转
    本文实例为大家分享了iOS实现音乐播放器图片旋转的具体代码,供大家参考,具体内容如下 通过给继承与 UIImageView 的类 CXGImageView 添加 CABasicAni...
    99+
    2022-05-26
    iOS 播放器 图片旋转
  • PHP实现图片旋转的方法详解
    最近有一个需求需要将前端上传过来的图片进行逆时针旋转90°,这个主要需要使用到php的imagerotate方法对于图片进行旋转,具体实现方法如下: <php na...
    99+
    2022-11-13
    PHP图片旋转方法 PHP图片旋转 PHP 旋转
  • Android实现图片反转、翻转、旋转、放大和缩小
    ********************************************************************** android 实现图片的翻转 ...
    99+
    2022-06-06
    图片 反转 Android
  • react怎么实现图片验证
    本教程操作环境:Windows10系统、react18版、Dell G3电脑。react怎么实现图片验证?react实现图片验证码效果如图所示:import React, { Component } from 'react'...
    99+
    2023-05-14
    React
  • vue实现图片滑动验证
    本文实例为大家分享了vue实现图片滑动验证的具体代码,供大家参考,具体内容如下 效果图: 1、引用自定义组件 import img0 from '../assets/img.jpg...
    99+
    2022-11-13
  • react如何实现图片验证
    这篇文章主要介绍“react如何实现图片验证”,在日常操作中,相信很多人在react如何实现图片验证问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”react如何实现图片验证”的疑惑有所帮助!接下来,请跟着小编...
    99+
    2023-07-04
  • Android UI之ImageView实现图片旋转和缩放
    这一篇,给大家介绍一下ImageView控件的使用,ImageView主要是用来显示图片,可以对图片进行放大、缩小、旋转的功能。 android:sacleType属性指定Im...
    99+
    2022-06-06
    图片 Android
  • Android 图片缩放与旋转的实现详解
    本文使用Matrix实现Android实现图片缩放与旋转。示例代码如下: 代码如下:package com.android.matrix;import android.app....
    99+
    2022-06-06
    图片 Android
  • html5怎么实现图片的3D旋转效果
    本篇内容主要讲解“html5怎么实现图片的3D旋转效果”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“html5怎么实现图片的3D旋转效果”吧!   完整代码如...
    99+
    2022-10-19
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作