亚洲精品久久久中文字幕-亚洲精品久久片久久-亚洲精品久久青草-亚洲精品久久婷婷爱久久婷婷-亚洲精品久久午夜香蕉

您的位置:首頁技術(shù)文章
文章詳情頁

Vue.js中動態(tài)更改svg的相關(guān)屬性詳解

瀏覽:80日期:2022-06-02 08:54:37
目錄
  • 引言
  • 怎樣將一個遠(yuǎn)程的svg圖標(biāo)資源"下載"到本地
  • 怎樣更改svgdom結(jié)構(gòu)里面的相關(guān)屬性

引言

公司項目中有一個關(guān)于圖標(biāo)庫管理的需求,大致需要在頁面能夠動態(tài)去更改對應(yīng)svg圖標(biāo)的大小、顏色等(這里的更改顏色限制線性圖標(biāo))。在網(wǎng)上查找了相關(guān)資料,做了技術(shù)的預(yù)研及demo的編寫,在此記錄一下。

怎樣將一個遠(yuǎn)程的svg圖標(biāo)資源"下載"到本地

首頁我們可以利用XMLHttpRequest對象來請求對應(yīng)的svg圖標(biāo)的遠(yuǎn)程資源鏈接地址,并監(jiān)聽實現(xiàn)XMLHttpRequest對象的load事件,將返回的資源進(jìn)行dom對象的轉(zhuǎn)換、string轉(zhuǎn)換為xml。

代碼如下:

const xhr = new XMLHttpRequest();      xhr.open("GET", "https://www.xx.com/img/xxx.svg", true);      xhr.send();      /* 監(jiān)聽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);      });

這里的工具函數(shù)stringToXml的完整代碼如下:

//將字符串轉(zhuǎn)化成dom對象;string轉(zhuǎn)換為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;}

這樣就可以獲取到遠(yuǎn)程svg資源對應(yīng)的dom結(jié)構(gòu)了。

怎樣更改svgdom結(jié)構(gòu)里面的相關(guān)屬性

產(chǎn)品的要求需要能夠動態(tài)更改對應(yīng)svg圖標(biāo)的寬、高、顏色值等。要實現(xiàn)這樣的功能有以下幾個小點:

  • 將svgDom對象轉(zhuǎn)換成vue的虛擬dom,代碼如下:const oSerializer = new XMLSerializer()
  • 根據(jù)序列化的對象提供的serializeToString方法將svgDom對象進(jìn)行字符串化;

通過svgDom對象提供的寬、高屬性值,結(jié)合正則來遍歷svgDom字符串化后的字符串,進(jìn)行寬高值的替換。代碼如下:

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"")
  • 根據(jù)sXML來截取svg結(jié)構(gòu)表示的字符串里對應(yīng)的顏色值,并結(jié)合is-color這個插件判斷是否是一個真正的顏色,是的話,根據(jù)想要替換的顏色值進(jìn)行全局替換就行。代碼如下:
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方法創(chuàng)建實例并掛載到某個元素上,代碼如下:
const Profile = Vue.extend({  template: "<div id="svgTemplate">" + sXML + "</div>"});// 創(chuàng)建實例,并掛載到元素上new Profile().$mount("#svgTemplate");

處理前的效果圖:

處理后的效果圖(將svg寬高由原來的20變?yōu)?0,將顏色值改為"#90EE90"):

最終完整的代碼如下:

testSvg () {      const xhr = new XMLHttpRequest();      xhr.open("GET", "https://www.xx.com/img/xxx.svg", true);      xhr.send();      /* 監(jiān)聽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對象轉(zhuǎn)換成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>"});// 創(chuàng)建實例,并掛載到元素上new Profile().$mount("#svgTemplate");      });    },

以上就是Vue.js中動態(tài)更改svg的相關(guān)屬性詳解的詳細(xì)內(nèi)容,更多關(guān)于Vue.js動態(tài)更改svg屬性的資料請關(guān)注其它相關(guān)文章!

標(biāo)簽: JavaScript
主站蜘蛛池模板: 青青青青啪视频在线观看 | 12306播播影视播播影院午夜 | 三级很黄很黄的视频 | 国产在线欧美精品中文一区 | 国产免费无遮挡精品视频 | 国产777| 深夜小视频在线观看 | 国产精品久久久久久久久久久久久久 | 国产伦一区二区三区四区久久 | 特黄特色大片免费高清视频 | 欧美一区二区三区国产精品 | 午夜视频成人 | 中文字幕在线永久在线视频2020 | 最新91网址| 亚洲欧美视频 | 国产亚洲精品一区二区在线播放 | 男女午夜爱爱久久无遮挡 | 欧美毛片精品一区 | 国产精品免费网站 | 国产精品自拍在线 | 我想看一级黄色毛片 | 六月丁香婷婷色狠狠久久 | 三级黄色免费网站 | 中国女人三级在线播放 | 免费在线观看黄色毛片 | 国产高清大尺度一区二区不卡 | 特级片免费看 | 亚洲精品国产第七页在线 | 黄色影 | 久久精品国产一区 | 国产资源在线看 | 永久免费看www色视频 | 高清性色生活片免费视频软件 | 亚洲日韩成人 | 国产1页| 国产精品久久久久亚洲 | 久久综合中文字幕一区二区三区 | 亚洲看片 | 二色a v国产 | 久热re这里只有精品视频 | 国产午夜精品一区二区三区嫩草 |