vue系列--图片通过鼠标滚轮放大缩小指令

1.将以下代码复制到src/directives/wheel-scale/index.js路径下

export const initVWheelScale = (Vue) => {Vue.directive("wheelScale", (el, binding) => {const {maxScale = 5,minScale = 0.5,initScale = 1,cssVarName = "--scale",} = binding.arg || {}let currentScale = initScale || el.style.getPropertyValue(cssVarName) || 1setWheelScale(binding, {el,cssVarName,currentScale,minScale,maxScale,})if (el) {el.onwheel = (e) => {currentScale = el.style.getPropertyValue(cssVarName) || 1if (e.wheelDelta > 0) {currentScale = currentScale * 1 + 0.1} else {currentScale = currentScale * 1 - 0.1}setWheelScale(binding, {el,cssVarName,currentScale,minScale,maxScale,})}}})
}
// 设置 --scale 变量 缩放比例
const setVarScale = (el, cssVarName, currentScale, minScale, maxScale) => {// 现在缩放范围if (currentScale > maxScale) {currentScale = maxScale} else if (currentScale < minScale) {currentScale = minScale}let cssText = el.style.cssTextlet cssTextList = cssText.split(";")let isExist = falselet isExistIndex = -1for (let index = 0; index < cssTextList.length; index++) {const element = cssTextList[index]if (element.includes(cssVarName + ":")) {isExist = trueisExistIndex = indexbreak}}if (isExist) {cssTextList[isExistIndex] = `--scale: ${currentScale}`} else {cssTextList.push(`--scale: ${currentScale}`)//   el.setAttribute("style", `--scale: ${currentScale}`)}cssText = cssTextList.join(";")el.style.cssText = cssTextreturn currentScale
}
// 设置 style.transform
const setTransformCss = (el, cssVarName) => {let transformCssString = el.style.transformlet regScaleGlobal = /scale\(.*?[ )]*[)]+[ ]*/g //匹配 Scale属性 全局if (regScaleGlobal.test(transformCssString)) {transformCssString = transformCssString.replace(regScaleGlobal,` scale(var(${cssVarName})) `)} else {transformCssString += " " + `scale(var(${cssVarName}))`}el.style.transform = transformCssString
}
export const setWheelScale = (binding = {}, options) => {const { el, cssVarName, currentScale, minScale, maxScale } = optionsconst nowScale = setVarScale(el, cssVarName, currentScale, minScale, maxScale)setTransformCss(el, cssVarName)// 缩放改变回调函数const wheelScaleHandle = binding.value || nullif (wheelScaleHandle instanceof Function) {wheelScaleHandle({el,cssVarName,maxScale,minScale,currentScale: nowScale,setScale: (_scale) => {setWheelScale(binding, { ...options, currentScale: _scale })},binding,})}
}

2.在main.js中注册全局指令

import { initVWheelScale} from "@/directives/wheel-scale"
initVWheelScale(Vue)

3.在需要用到的组件中的dom元素上使用即可

v-wheelScale

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Linux 学习笔记(4)

四、 文件权限 1 、文件类型 Linux 广泛的被很多用户所接受&#xff0c;它强大的功能受到很多人喜欢&#xff0c; Linux 文件一般是用一些相关的应 用程序创建&#xff0c;比如图像工具、文档工具、归档工具 ... .... 或 cp 工具等。 Linux 文件的删除方式是用 rm 命…

动态规划的时间复杂度优化

作者推荐 视频算法专题 本文涉及知识点 动态规划汇总 优化动态规划的时间复杂度&#xff0c;主要有如下几种&#xff1a; 一&#xff0c;不同的状态表示。 比如&#xff1a;n个人&#xff0c;m顶帽子。 第一种方式&#xff1a;dp[i][mask] ,i表示前i个人已经选择帽子&…

再见,Visual Basic——曾经风靡一时的编程语言

2020年3月&#xff0c;微软团队宣布了对Visual Basic&#xff08;VB&#xff09;的“终审判决”&#xff1a;不再进行开发或增加新功能。这意味着曾经风光无限的VB正式退出了历史舞台。 VB是微软推出的首款可视化编程软件&#xff0c;自1991年问世以来&#xff0c;便受到了广大…

国际生物发酵产品技术展2024-齐力控股

参展企业介绍 齐力控股集团凭借在此领域多年的生产经验&#xff0c;为客户提供各种优质的产品。齐力控股集团与世界同步的生产宗旨&#xff0c;确立完整的角色定位和明确方向&#xff0c;向大众传递本公司的营销特点和服务模式。本公司是一家集科研、生产为一体的现代企业&…

2024-02-26(金融AI行业概览与大数据生态圈)

1.最开始的风控是怎么做的&#xff1f; 人审 吃业务经验 不能大批量处理&#xff0c;效率低下 不适用于移动互联网的金融场景 2.建模的概念 建模就是构造一个数学公式&#xff0c;能将我们手上有的数据输入进去&#xff0c;通过计算得到一些预测结果。 比如初高中学习的…

如何进行Appium实现移动端UI自动化测试?

&#x1f345; 视频学习&#xff1a;文末有免费的配套视频可观看 &#x1f345; 关注公众号【互联网杂货铺】&#xff0c;回复 1 &#xff0c;免费获取软件测试全套资料&#xff0c;资料在手&#xff0c;涨薪更快 Appium是一个开源跨平台移动应用自动化测试框架。 既然只是想学…

瑞_Redis_Redis客户端

文章目录 1 Redis客户端1.1 Redis命令行客户端1.2 图形化桌面客户端1.2.1 资源准备1.2.2 安装1.2.3 建立连接 &#x1f64a; 前言&#xff1a;本文章为瑞_系列专栏之《Redis》的基础篇的Redis客户端章节。由于博主是从B站黑马程序员的《Redis》学习其相关知识&#xff0c;所以本…

Spring11、整合Mybatis

11、整合Mybatis 步骤&#xff1a; 导入相关jar包 junit <dependency><groupId>junit</groupId><artifactId>junit</artifactId><version>4.12</version> </dependency> mybatis <dependency><groupId>org.my…

Qt QWidget 简约美观的加载动画 第二季

&#x1f603; 第二季来啦 &#x1f603; 简约的加载动画,用于网络查询等耗时操作时给用户的提示. 这是最终效果: 一共只有三个文件,可以直接编译运行 //main.cpp #include "LoadingAnimWidget.h" #include <QApplication> #include <QVBoxLayout> #i…

如何保护企业免受人工智能网络钓鱼攻击

文章目录 前言一、生成式人工智能带来了新的网络安全威胁二、人工智能将使网络钓鱼攻击变得更加危险三、企业如何阻止人工智能驱动的网络钓鱼四、网络钓鱼模拟确保责任感和适应性前言 网络钓鱼是网络犯罪分子社会工程武器库中的超级武器。网络钓鱼尤其危险,因为它是网络犯罪分…

Redis 管道详解

Redis 管道 关键词&#xff1a;Pipeline Pipeline 简介 Redis 是一种基于 C/S 模型以及请求/响应协议的 TCP 服务。通常情况下&#xff0c;一个 Redis 命令的请求、响应遵循以下步骤&#xff1a; 客户端向服务端发送一个查询请求&#xff0c;并监听 Socket 返回&#xff08…

List根据实体类中某一字段进行去重

List根据实体类中某一字段进行去重 1、使用 toMap 收集器 利用 Collectors.toMap 收集器将流中的元素映射为一个 Map&#xff0c;其中键为 OmsOrderId&#xff0c;值为元素本身。如果存在相同的键&#xff08;即相同的 OmsOrderId&#xff09;&#xff0c;则使用 (existing, r…

美创科技荣获“2023年网络安全国家标准优秀实践案例”

近日&#xff0c;全国网络安全标准化技术委员会正式公布2023年网络安全国家标准优秀实践案例获奖名单。 杭州美创科技股份有限公司&#xff08;以下简称&#xff1a;美创科技&#xff09;申报的“GB/T 20281-2020《信息安全技术 防火墙安全技术要求和测试评价方法》在政企领域数…

【监督学习之支持向量机(SVM)】

曾梦想执剑走天涯&#xff0c;我是程序猿【AK】 目录 简述概要知识图谱基本原理支持向量线性SVM与非线性SVM优化问题软间隔与正则化SVM的应用实现 简述概要 了解监督学习-支持向量机&#xff08;SVM&#xff09; 知识图谱 支持向量机&#xff08;Support Vector Machine&…

visual stdio 使用ATL简单使用COM组件

先试用visual stdio创建ATL项目 选择第一个创建ATL简单对象 ProgId也需要添加一下&#xff0c;默认创建完之后添加方法 STDMETHODIMP AddNumber(LONG __num, LONG* result);添加定义 STDMETHODIMP_(HRESULT __stdcall) CATLSimpleObject::AddNumber(LONG __num, LONG* r…

LASSO算法

LASSO (Least Absolute Shrinkage and Selection Operator) 是一种回归分析的方法&#xff0c;它能够同时进行变量选择和正则化&#xff0c;以增强预测准确性和模型的解释性。LASSO通过在损失函数中加入一个L1惩罚项来实现这一点。该惩罚项对系数的绝对值进行约束。 基本概念 …

【深度学习笔记】深度卷积神经网络——AlexNet

深度卷积神经网络&#xff08;AlexNet&#xff09; 在LeNet提出后&#xff0c;卷积神经网络在计算机视觉和机器学习领域中很有名气。但卷积神经网络并没有主导这些领域。这是因为虽然LeNet在小数据集上取得了很好的效果&#xff0c;但是在更大、更真实的数据集上训练卷积神经网…

Linux 学习笔记(1-3)

一、 常用命令 LINUX 常用操作命令和命令行编辑快捷键 终端快捷键&#xff1a; Ctrl a/Home 切换到命令行开始 Ctrl e/End 切换到命令行末尾 Ctrl l 清除屏幕内容&#xff0c;效果等同于 clear Ctrl u 清除剪切光标之前的内容 Ctrl k 剪切清除光标之后的内容…

数学建模论文、代码百度网盘链接

1.[2018中国大数据年终总决赛冠军] 金融市场板块划分与轮动规律挖掘与可视化问题 2.[2019第九届MathorCup数模二等奖] 数据驱动的城市轨道交通网络优化策略 3.[2019电工杯一等奖] 露天停车场停车位的优化设计 4.[2019数学中国网络数模一等奖] 基于机器学习的保险业数字化变革…

后端分布式系统:提高可靠性和可伸缩性的架构

在当今的数字时代&#xff0c;随着用户数量和数据量的不断增长&#xff0c;传统的集中式系统已经难以满足企业的需求。为了解决这些挑战&#xff0c;后端分布式系统应运而生。这种架构将系统的不同组件分布在多个计算机上&#xff0c;通过网络进行通信和协调&#xff0c;从而提…