Vue中如何通过XMLHttpRequest调整svg的属性
Admin 2023-04-06 群英技术资讯 886 次浏览
公司项目中有一个关于图标库管理的需求,大致需要在页面能够动态去更改对应svg图标的大小、颜色等(这里的更改颜色限制线性图标)。在网上查找了相关资料,做了技术的预研及demo的编写,在此记录一下。
首页我们可以利用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对象 */ 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转换为xml function 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
结构了。
产品的要求需要能够动态更改对应svg图标的宽、高、颜色值等。要实现这样的功能有以下几个小点:
const oSerializer = new XMLSerializer()
;serializeToString
方法将svgDom
对象进行字符串化;通过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"')
sXML
来截取svg
结构表示的字符串里对应的颜色值,并结合is-color
这个插件判断是否是一个真正的颜色,是的话,根据想要替换的颜色值进行全局替换就行。代码如下: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')
Vue
实例提供的extend
方法创建实例并挂载到某个元素上,代码如下:const Profile = Vue.extend({ template: "<div id='svgTemplate'>" + sXML + '</div>' }); // 创建实例,并挂载到元素上 new Profile().$mount('#svgTemplate');
处理前的效果图:
处理后的效果图(将svg宽高由原来的20变为40,将颜色值改为"#90EE90"):
最终完整的代码如下:
testSvg () { const xhr = new XMLHttpRequest(); xhr.open('GET', 'https://www.xx.com/img/xxx.svg', true); xhr.send(); /* 监听xhr对象 */ 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); /* 将svgDom对象转换成vue的虚拟dom */ 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'); }); },
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
这篇文章主要为大家详细介绍了vue卡片式点击切换图片组件的使用方法,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
解构赋值是一种特殊的语法,它使我们可以将数组或对象“拆包”为到一系列变量中,因为有时候使用变量更加方便,下面这篇文章主要给大家介绍了关于JavaScript解构赋值的5个常见场景与实例的相关资料,需要的朋友可以参考下
我们都知道urlencode编码一般用于url网址中,它的格式是带有 % 符号的十六进制编码,起着保护隐私的作用,例如这段url编码“%ce%d2%ca%c7%d6%d0%b9%fa%c8%cb(我是中国人)”,是gbk版本的,那么我们该如何来使用js解析这一段gbk2313的编码呢?代码如下: //
这篇文章给大家分享的是有关vue 动态创建组件的内容,下文给大家介绍了vue 动态创建组件并挂载到body的两种方式,有具体代码供大家参考,需要的朋友可以了解一下。
这篇文章主要为大家详细介绍了js仿淘宝放大镜效果,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
成为群英会员,开启智能安全云计算之旅
立即注册Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008