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

相关推荐
布列瑟农的星空17 分钟前
WebAssembly入门(一)——Emscripten
前端·后端
贵州数擎科技有限公司20 分钟前
一批优质 AI 域名转让(.ai)|适合 AI 创业 / 产品 / 公司品牌
前端
小二·27 分钟前
微前端架构完全指南:qiankun 与 Module Federation 双方案深度对比(Vue 3 + TypeScript)
前端·架构·typescript
EndingCoder1 小时前
枚举类型:常量集合的优雅管理
前端·javascript·typescript
@AfeiyuO1 小时前
Vue3 高德地图
vue·echarts
Electrolux1 小时前
[wllama]纯前端实现大语言模型调用:在浏览器里跑 AI 是什么体验。以调用腾讯 HY-MT1.5 混元翻译模型为例
前端·aigc·ai编程
sanra1231 小时前
前端定位相关技巧
前端·vue
起名时在学Aiifox1 小时前
从零实现前端数据格式化工具:以船员经验数据展示为例
前端·vue.js·typescript·es6
cute_ming1 小时前
关于基于nodeMap重构DOM的最佳实践
java·javascript·重构
oMcLin2 小时前
如何在Manjaro Linux上配置并优化Caddy Web服务器,确保高并发流量下的稳定性与安全性?
linux·服务器·前端