文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

Vue.js中怎么动态更改svg的相关属性

2023-07-05 05:39

关注

本篇内容介绍了“Vue.js中怎么动态更改svg的相关属性”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!

怎样将一个远程的svg图标资源"下载"到本地

首页我们可以利用XMLHttpRequest对象来请求对应的svg图标的远程资源链接地址,并监听实现XMLHttpRequest对象的load事件,将返回的资源进行dom对象的转换、string转换为xml。

代码如下:

const xhr = new XMLHttpRequest();      xhr.open('GET', 'https://www.xx.com/img/xxx.svg', true);      xhr.send();            xhr.onreadystatechange = function () {        if (xhr.readyState == 4 && xhr.status == 200) {          console.log(xhr.responseXML, 'xhr.responseXML---------')        }      };      xhr.addEventListener('load', () => {        const resXML = stringToXml(xhr.response);        this.svgDom = resXML.documentElement.cloneNode(true);      });

这里的工具函数stringToXml的完整代码如下:

//将字符串转化成dom对象;string转换为xmlfunction stringToXml (xmlString) {  let xmlDoc;  if (typeof xmlString == "string") {    //FF    if (document.implementation.createDocument) {      const parser = new DOMParser();      xmlDoc = parser.parseFromString(xmlString, "text/xml");    } else if (window.ActiveXObject) {      // eslint-disable-next-line no-undef      xmlDoc = new ActiveXObject("Microsoft.XMLDOM");      xmlDoc.async = false;      xmlDoc.loadXML(xmlString);    }  }  else {    xmlDoc = xmlString;  }  return xmlDoc;}

这样就可以获取到远程svg资源对应的dom结构了。

怎样更改svgdom结构里面的相关属性

产品的要求需要能够动态更改对应svg图标的宽、高、颜色值等。要实现这样的功能有以下几个小点:

通过svgDom对象提供的宽、高属性值,结合正则来遍历svgDom字符串化后的字符串,进行宽高值的替换。代码如下:

let sXML = oSerializer.serializeToString(this.svgDom);sXML = sXML.replace(`width="${this.svgDom.width.baseVal.value}"`, 'width="40"').replace(`height="${this.svgDom.height.baseVal.value}"`, 'height="40"')
let curColor = sXML.split('#')[1].substr(0, 6)      if (!isColor(`#${curColor}`)) {        curColor = sXML.split('#')[1].substr(0, 3)      }      sXML = sXML.replace(new RegExp(`#${curColor}`, "gm"), '#90EE90')
const Profile = Vue.extend({          template: "<div id='svgTemplate'>" + sXML + '</div>'        });        // 创建实例,并挂载到元素上        new Profile().$mount('#svgTemplate');

处理前的效果图:

Vue.js中怎么动态更改svg的相关属性

处理后的效果图(将svg宽高由原来的20变为40,将颜色值改为"#90EE90"):

Vue.js中怎么动态更改svg的相关属性

最终完整的代码如下:

testSvg () {      const xhr = new XMLHttpRequest();      xhr.open('GET', 'https://www.xx.com/img/xxx.svg', true);      xhr.send();            xhr.onreadystatechange = function () {        if (xhr.readyState == 4 && xhr.status == 200) {          console.log(xhr.responseXML, 'xhr.responseXML---------')        }      };      xhr.addEventListener('load', () => {        const resXML = stringToXml(xhr.response);        this.svgDom = resXML.documentElement.cloneNode(true);                const oSerializer = new XMLSerializer();        let sXML = oSerializer.serializeToString(this.svgDom);        let curColor = sXML.split('#')[1].substr(0, 6)        if (!isColor(`#${curColor}`)) {          curColor = sXML.split('#')[1].substr(0, 3)        }        sXML = sXML.replace(`width="${this.svgDom.width.baseVal.value}"`, 'width="40"').replace(`height="${this.svgDom.height.baseVal.value}"`, 'height="40"').replace(new RegExp(`#${curColor}`, "gm"), '#90EE90')        const Profile = Vue.extend({          template: "<div id='svgTemplate'>" + sXML + '</div>'        });        // 创建实例,并挂载到元素上        new Profile().$mount('#svgTemplate');      });    },

“Vue.js中怎么动态更改svg的相关属性”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注编程网网站,小编将为大家输出更多高质量的实用文章!

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯