el-image实现旋转修改保存

2024.4.8今天我学习了用el-image组件如何实现图片的旋转然后保存旋转之后的图片,

代码如下:

一、新增确定按钮。

<template>
 <el-image  src='@/assets/xxx/xxx' @click='clickImage('@/assets/xxx/xxx')'/>
</template>

<script>
export default{
  data(){
    return{
            img_url :''//存放图片路径
        }
  }
  methods:{
    clickImage(url){
      this.img_url = url//获取选中图片路径
      this.$nextTick(() => {
        let wrapper = document.getElementsByClassName(
          'el-image-viewer__actions__inner'
        )
        let downImg = document.createElement('i')
        downImg.setAttribute('class', 'el-icon-check')
        wrapper[0].appendChild(downImg)
        if (wrapper.length > 0) {
          wrapper[0].addEventListener('click', event => {
            this.cusClickHandler(event); // 通过箭头函数将事件对象传递给cusClickHandler 方法
          });
        }
      })
     }
  }
}
</script>

二、写新增按钮的逻辑

主要用document.getElementsByClassName获取相关按钮的类名,通过类名设置点击事件,然后拿到图片的旋转角度,最重要的一点就是要拿到旋转之后的图片,目前我想到有两种方法:

(1)旋转好的图片前端用画布画出来然后传给后端存储。

(2)把旋转的图片路径和旋转角度传给后端,让后端旋转好图片进行覆盖。(目前用的这种)

<template>
 <el-image  src='@/assets/xxx/xxx' @click='clickImage('@/assets/xxx/xxx')'/>
</template>

<script>
export default{
  data(){
    return{
            img_url :''//存放图片路径
        }
  }
  methods:{
    clickImage(url){
      this.img_url = url//获取选中图片路径
      this.$nextTick(() => {
        let wrapper = document.getElementsByClassName(
          'el-image-viewer__actions__inner'
        )
        let downImg = document.createElement('i')
        downImg.setAttribute('class', 'el-icon-check')
        wrapper[0].appendChild(downImg)
        if (wrapper.length > 0) {
          wrapper[0].addEventListener('click', event => {
            this.cusClickHandler(event); // 通过箭头函数将事件对象传递给cusClickHandler 方法
          });
        }
      })
     },

    cusClickHandler(e) {
      if (e !== undefined) {//点击图片会触发,所以要判断
        // 旋转照片(顺时针||逆时针)
        if (e.target.className === 'el-icon-refresh-right' || 'el-icon-refresh-left') {
          let imgUrl = this.img_url
          let element = document.getElementsByClassName('el-image-viewer__img')
          let degA = element[0].style.transform.substring(16)
          let deg = degA.substring(0, degA.length - 4)//拿到旋转角度
          // 确认修改
          if (e.target.className === 'el-icon-check') {
            let upload_data = {
              url: imgUrl,//图片路径
              angle: -deg//图片旋转角度
            }
                //调用接口
            xxxxxxxx(upload_data).then(res => {
                 //关闭页面
                let close = document.querySelector('.el-image-viewer__close')
                close.click()
             
            })
          }
        }
      }
    }
  }
}
</script>

效果如下:

三、旋转保存重新渲染

当图片可以旋转保存之后会重新图片没有重新渲染的情况,这是因为浏览器的缓存机制,所以我们需要给图片进行重新渲染,增加一个key值,在src上面也需要绑定,(注意:看了其他的案例,都是绑定一个随机数new DateTime(),这样会导致你在做其他操作的时候,图片会一直重新渲染,所以还是用key值在点击确定时候进行重新渲染比较好)

<template>
 <el-image  :src="'@/assets/xxx/xxx'+'?'+image_id" @click='clickImage('@/assets/xxx/xxx')' :key='image_id'/>
</template>

<script>
export default{
  data(){
    return{
            img_url :'',//存放图片路径
            image_id:0,//渲染图片
        }
  }
  methods:{
    clickImage(url){
      this.img_url = url//获取选中图片路径
      this.$nextTick(() => {
        let wrapper = document.getElementsByClassName(
          'el-image-viewer__actions__inner'
        )
        let downImg = document.createElement('i')
        downImg.setAttribute('class', 'el-icon-check')
        wrapper[0].appendChild(downImg)
        if (wrapper.length > 0) {
          wrapper[0].addEventListener('click', event => {
            this.cusClickHandler(event); // 通过箭头函数将事件对象传递给cusClickHandler 方法
          });
        }
      })
     },

    cusClickHandler(e) {
      if (e !== undefined) {//点击图片会触发,所以要判断
        // 旋转照片(顺时针||逆时针)
        if (e.target.className === 'el-icon-refresh-right' || 'el-icon-refresh-left') {
          let imgUrl = this.img_url
          let element = document.getElementsByClassName('el-image-viewer__img')
          let degA = element[0].style.transform.substring(16)
          let deg = degA.substring(0, degA.length - 4)//拿到旋转角度
          // 确认修改
          if (e.target.className === 'el-icon-check') {
            let upload_data = {
              url: imgUrl,//图片路径
              angle: -deg//图片旋转角度
            }
                //调用接口
            xxxxxxxx(upload_data).then(res => {
                 //关闭页面
                let close = document.querySelector('.el-image-viewer__close')
                close.click()
                this.image_id++
            })
          }
        }
      }
    }
  }
}
</script>

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/542876.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

redis的设计与实现(五)——独立功能

1. Redis的其他功能 redis 除了简单对对象的增删改查的功能之外&#xff0c;其实还有其他高级功能&#xff0c;了解这些内容有利于我们更灵活的使用 redis 完成我们的业务功能。 2. 发布与订阅 2.1. 基本概念 很多中间件都有发布与订阅功能&#xff0c;但是&#xff0c;作为一…

leetcode经典困难题-接雨水

. - 力扣&#xff08;LeetCode&#xff09; 42. 接雨水 困难 相关标签 相关企业 给定 n 个非负整数表示每个宽度为 1 的柱子的高度图&#xff0c;计算按此排列的柱子&#xff0c;下雨之后能接多少雨水。 示例 1&#xff1a; 输入&#xff1a;height [0,1,0,2,1,0,1,3,2,1,…

申请OV SSL证书

OV证书&#xff0c;即Organization Validation证书&#xff0c;是一种SSL/TLS证书类型&#xff0c;主要用于企业级应用&#xff0c;例如教育、政府、互联网等行业的大型企业和政府机关部门。与基础的域名验证&#xff08;DV&#xff09;证书相比&#xff0c;OV证书的验证过程更…

【笔记】mysql版本6以上时区问题

前言 最近在项目中发现数据库某个表的createTime字段的时间比中国时间少了13个小时&#xff0c;只是在数据库中查看显示时间不对&#xff0c;但是在页面&#xff0c;又是正常显示中国时区的时间。 排查 项目中数据库的驱动使用的是8.0.19&#xff0c;驱动类使用的是com.mysq…

【Canvas与艺术】绘制安布雷拉Umbrella伞公司标志

【关键点】 圆弧圆心的定位和起止角度。 【成果图】 【代码】 <!DOCTYPE html> <html lang"utf-8"> <meta http-equiv"Content-Type" content"text/html; charsetutf-8"/> <head><title>安布雷拉Umbrella伞公司…

数字经济专家高泽龙担任工信部元宇宙标准化委员会委员

数字经济专家高泽龙受聘担任工信部元宇宙标准化委员会委员&#xff0c;出席工作组成立大会暨第一次全体委员会议。 第一届元宇宙国标、团标以及标委会工作组会议顺利召开&#xff01; 同时&#xff0c;正式成为工信部中国人工智能产业发展联盟科技伦理工作组成员&#xff01;

css 实现排行榜向上滚动

使用动画实现无线向上滚动 复制一层dom&#xff0c;使用动画向上滚动&#xff0c;鼠标hover的时候暂停动画 <!DOCTYPE html> <html lang"en"><head><meta charset"UTF-8"><meta name"viewport" content"widthd…

【相机方案】智能驾驶的域控采用的“串行器和解串器”方案的总结(持续更新),SerDes,GMSL

SerDes是Serializer/Deserializer的缩写&#xff0c;即串行器和解串器。由于同轴线的传输延迟几乎可以忽略不计&#xff08;ns级别&#xff09;&#xff0c;相当于将原来只能短距离传输的高速并行信号(MIPI/I2C/CLK等)的传输距离延长&#xff0c;真正做到高带宽、低延迟、长距离…

潍微科技-水务信息管理平台 ChangePwd SQL注入漏洞复现(CNVD-2024-14945)

0x01 免责声明 请勿利用文章内的相关技术从事非法测试&#xff0c;由于传播、利用此文所提供的信息而造成的任何直接或者间接的后果及损失&#xff0c;均由使用者本人负责&#xff0c;作者不为此承担任何责任。工具来自网络&#xff0c;安全性自测&#xff0c;如有侵权请联系删…

计算机网络书籍--《网络是怎样连接的》阅读笔记

第一章 浏览器生成信息 1.1 生成HTTP请求信息 1.1.1 URL Uniform Resource Locator, 统一资源定位符。就是网址。 不同的URL能够用来判断使用哪种功能来访问相应的数据&#xff0c;比如访问Web服务器就要用”http:”&#xff0c;而访问FTP服务器用”ftp:”。 FTP&#xff…

QT常用控件

常用控件 控件概述QWidget 核⼼属性核⼼属性概览enabledgeometrywindowTitlewindowIconwindowOpacitycursorfonttoolTipfocusPolicystyleSheet 按钮类控件Push ButtonRadio ButtionCheck Box 显⽰类控件LabelLCD NumberProgressBarCalendar Widget 输⼊类控件Line EditText Edi…

每日一题:缺失的第一个正数

给你一个未排序的整数数组 nums &#xff0c;请你找出其中没有出现的最小的正整数。 请你实现时间复杂度为 O(n) 并且只使用常数级别额外空间的解决方案。 示例 1&#xff1a; 输入&#xff1a;nums [1,2,0] 输出&#xff1a;3 解释&#xff1a;范围 [1,2] 中的数字都在数组…

【微服务】------架构设计及常用组件

前言 在当今迅猛发展的软件开发领域&#xff0c;微服务架构已经成为构建灵活、可扩展系统的关键方法之一。本文将带领读者深入了解微服务架构的核心思想&#xff0c;并介绍构建这一架构所需的常用组件&#xff0c;为各位开发者提供全面的指导和洞察力。 BigDiagram 我们从一…

2024年4月8日腾讯云故障复盘及情况说明

2024年4月8日15点23分&#xff0c;腾讯云团队收到告警信息&#xff0c;云API服务处于异常状态&#xff1b;随即在腾讯云工单、售后服务群以及微博等渠道开始大量出现腾讯云控制台登录不上的客户反馈。 经过故障定位发现&#xff0c;客户登录不上控制台正是由云API异常所导致。云…

jmeter使用之生成html测试报告

测试的最终结果是需要给出一份报告&#xff0c;那么在用jmeter测试时怎么生成一份报告呢&#xff0c;以下针对jmeter如何生成html报告进行简单介绍 一、首先把测试脚本写好二、利用命令生成html报告 命令&#xff1a;jmeter -n -t 【Jmx脚本位置】-l 【结果文件result.jtl存放…

【vue】defineEmits 传值 子传父

先行知识 【vue】导入组件【vue】defineProps 传数据 父传子 传值流程 App.vue <template><Header getWeb"emitsGetWeb" userAdd"emitsUserAdd"/><hr /><p>web.name: {{ web.name }}</p><p>web.url: {{ web.url }}&…

【浅学】大模型(科普向_持续更新中)

1. 大模型概述 大模型是指具有数千万甚至数亿参数的深度学习模型。 当我们提及大模型时&#xff0c;通常指的是大语言模型&#xff08;Large Language Model&#xff0c;简称LLM&#xff09;&#xff0c;即文字问答模型&#xff0c;其典型代表便是OpenAI的GPT系列。然而&…

【PyTorch】设置CUDA_VISIBLE_DEVICES无效的问题以及多卡使用以及CUDA out of memory问题

方法1&#xff1a; 理想情况下&#xff0c;该环境变量应设置在程序的顶部。如果在设置 torch.backends.cudnn.benchmark 之后调用 CUDA_VISIBLE_DEVICES 变量&#xff0c;则更改 CUDA_VISIBLE_DEVICES 变量将不起作用。 import os os.environ["CUDA_VISIBLE_DEVICES"…

Wpf 使用 Prism 实战开发Day18

数据加载动画实现 概要&#xff1a; 当打开功能页面时&#xff0c;在数据未加载完毕前&#xff0c;希望有一个友好的等待提示。那么&#xff0c;本章通过学习Prism 中事件聚合器&#xff08;EventAggregator&#xff09;&#xff0c;并通过创建等待提示窗口&#xff0c;同时结…

asp.net core 网页接入微信扫码登录

创建微信开放平台账号&#xff0c;然后创建网页应用 获取appid和appsecret 前端使用的vue&#xff0c;安装插件vue-wxlogin 调用代码 <wxlogin :appid"appId" :scope"scope" :redirect_uri"redirect_uri"></wxlogin> <scri…