vue引入svg文件及交互,使用svg-pan-zoom插件实现svg图放大缩小等操作

一、引入svg文件

1、若不需要交互,可以用img、iframe、object标签作为图片直接引入。

javascript 复制代码
<img src="images/year.svg" style="width: 100%" />
或
<iframe src="images/year.svg" frameborder="0" style="width: 100%; height: 100%;"></iframe>
或
<object data="images/year.svg" style="width: 100%; height: 100%;"></object>

2、若需要与其交互,如设置svg文件中的元素显示隐藏、更改文字内容等操作,则需要作为元素加载到页面中。

javascript 复制代码
<template>
    <div class="box">
        <div id="svgElement" v-html="svgContent"></div>
    </div>
</template>
<script>
    import axios from 'axios';
    export default {
        data () {
            return {
                svgContent: ''
            }
        },
        mounted () {
            this.initSvgEle();
        },
        methods: {
            // 初始化svg底图
            initSvgEle () {
                axios.get('images/year.svg').then(res => {
                    if (res.status === 200 && res.data) {
                    	// 作为html渲染到页面中
                        this.svgContent = res.data;
                        // 设置某个元素隐藏,若有其他操作也可通过类似的方法获取到元素进行操作
                        this.$nextTick(() => {
                          document.querySelector('#defaultEle').style.display = 'none';
                        })
                    }
                })
            }
        }
    }
</script>
<style scoped lang="less">
    .box {
        height: 100%;
        width: 100%;
        /deep/#svgElement {
            width: 100%;
            height: 100%;
            & > svg {
                width: 100%;
                height: 100%;
            }
        }
    }
</style>

注:一般svg图中的元素没有进行id绑定,可通过专业的工具进行元素分组和id命名。

二、svg-pan-zoom插件

该插件提供了svg图像放大、缩小、平移、旋转等方法,用法如下:

javascript 复制代码
// 下载依赖:npm i svg-pan-zoom --save
import svgPanZoom from 'svg-pan-zoom';
svgPanZoom(document.querySelector("#svgElement > svg"), {
    zoomEnabled: true, // 允许缩放
    panEnabled: true, // 允许平移
    maxZoom: 5, // 最大缩放级别
    minZoom: 1, // 最小缩放级别
    dblClickZoomEnabled: true, // 允许双击放大
    controlIconsEnabled: true, // 显示放大、缩小、重置控制按钮
})

注:关于插件更多内容可查看 https://github.com/bumbu/svg-pan-zoom

相关推荐
信创DevOps先锋13 小时前
本土化突围:Gitee如何重新定义企业级项目管理工具价值
前端·gitee·jquery
圣光SG14 小时前
Java类与对象及面向对象基础核心详细笔记
java·前端·数据库
Jinuss14 小时前
源码分析之React中的useImperativeHandle
开发语言·前端·javascript
ZC跨境爬虫14 小时前
CSS核心知识点与定位实战全解析(结合Playwright爬虫案例)
前端·css·爬虫
Jinuss14 小时前
源码分析之React中的forwardRef解读
前端·javascript·react.js
mengsi5514 小时前
Antigravity IDE 在浏览器上 verify 成功但本地 IDE 没反应 “开启Tun依然无济于事” —— 解决方案
前端·ide·chrome·antigravity
南风知我意95714 小时前
JavaScript 惰性函数深度解析:从原理到实践的极致性能优化
开发语言·javascript·性能优化
Можно14 小时前
pages.json 和 manifest.json 有什么作用?uni-app 核心配置文件详解
前端·小程序·uni-app
hzhsec14 小时前
钓鱼邮件分析与排查
服务器·前端·安全·web安全·钓鱼邮件