日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

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

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

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

引言

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

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

首頁我們可以利用XMLHttpRequest對象來請求對應(yīng)的svg圖標(biāo)的遠(yuǎn)程資源鏈接地址,并監(jiān)聽實(shí)現(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)的寬、高、顏色值等。要實(shí)現(xiàn)這樣的功能有以下幾個(gè)小點(diǎ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這個(gè)插件判斷是否是一個(gè)真正的顏色,是的話,根據(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實(shí)例提供的extend方法創(chuàng)建實(shí)例并掛載到某個(gè)元素上,代碼如下:
const Profile = Vue.extend({  template: "<div id="svgTemplate">" + sXML + "</div>"});// 創(chuàng)建實(shí)例,并掛載到元素上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)建實(shí)例,并掛載到元素上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
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
好看不卡的中文字幕| 日韩va亚洲va欧美va久久| 精品亚洲免a| 欧美日韩国产高清| 欧美亚洲自偷自偷| 欧美理论视频| 精品国产一区二区三区2021| 日韩在线看片| 亚洲精品裸体| 日本免费一区二区三区四区| 9国产精品视频| 国产一区国产二区国产三区| 一区二区高清| 亚洲最新无码中文字幕久久 | 成人av二区| 亚州欧美在线| 久久精品国产68国产精品亚洲| 国产探花在线精品| 亚洲综合精品四区| 国产精品麻豆久久| 欧美日韩一区二区三区在线电影| 久久精品主播| 美腿丝袜亚洲三区| 日本欧美一区二区| 中文字幕免费一区二区| 欧美91视频| 日韩国产在线| 国产精品99一区二区三区| 国产日本亚洲| 亚洲97av| 蜜桃视频免费观看一区| 99视频一区| 99热精品久久| 欧美aa在线观看| 国产一区二区三区网| 国产精品网址| 欧美日一区二区在线观看| 亚洲资源网站| 国产日韩欧美中文在线| 欧美日韩1区2区3区| 久久av资源| 91看片一区| 国产一区亚洲| 久久亚洲影院| 欧美日韩1区| 麻豆一区二区在线| 久久精品91| 国产精品成人**免费视频| 欧美激情视频一区二区三区免费| 粉嫩av一区二区三区四区五区 | 国产一区不卡| 国产毛片精品| 免费日韩一区二区三区| 久久精品人人| 精品免费av在线| 国产一区清纯| 蜜臀av性久久久久蜜臀aⅴ流畅| 中文字幕免费一区二区| 国产精品一区二区av日韩在线| 国产欧美在线观看免费| 久久99国产精品视频| 女生影院久久| 午夜一区在线| 视频在线在亚洲| 久久精品99国产精品| 国产精品嫩模av在线| 老司机精品视频网| 欧美肉体xxxx裸体137大胆| 丝袜美腿成人在线| 欧美另类中文字幕| 日韩电影免费网站| 中文字幕亚洲影视| 久久久久久婷| 亚洲tv在线| 天堂а√在线最新版中文在线| 国产女优一区| 欧美a一区二区| 日韩午夜免费| 精品国产日韩欧美精品国产欧美日韩一区二区三区 | 午夜精品免费| 国产欧美日韩精品高清二区综合区| 精品理论电影在线| 亚洲视频二区| www.com.cn成人| 国产亚洲精品美女久久 | 麻豆高清免费国产一区| 免费精品视频在线| 欧美日韩国产v| 久久不见久久见国语| 红桃视频欧美| 美女一区网站| 国产在线日韩精品| 国产精品亚洲综合久久| 色吊丝一区二区| 亚洲综合小说| 久久精品国语| 久久不见久久见中文字幕免费| 欧美在线网站| 免费在线亚洲| 中文字幕亚洲在线观看| 国产一区二区精品久| 蜜臀va亚洲va欧美va天堂| 久久av资源| 丝瓜av网站精品一区二区| 福利欧美精品在线| 精品美女在线视频| 久久久精品五月天| 国产精品一区二区三区www| 图片区亚洲欧美小说区| 老牛影视精品| 国产精品videossex久久发布| 亚洲精品va| 欧洲一级精品| 免费视频一区二区三区在线观看| 一区二区三区四区在线观看国产日韩| 亚洲播播91| 最新中文字幕在线播放| 国产精品高清一区二区| 亚洲无线观看| 老司机精品久久| 色在线视频观看| 97精品在线| 精品一区二区三区中文字幕在线| 日韩高清不卡在线| 婷婷综合成人| 日韩影院精彩在线| 亚洲免费影视| 中文精品在线| 亚洲一区二区三区久久久| 少妇精品久久久| 日韩高清一区| 欧美久久精品一级c片| 99久久精品网站| 四虎4545www国产精品 | 亚洲欧洲美洲国产香蕉| 亚洲欧美日韩精品一区二区 | 尤物网精品视频| 99精品视频精品精品视频| 亚洲国产一区二区三区在线播放| 国产一区二区久久久久| 中文字幕日韩亚洲| 久久xxxx| 亚洲开心激情| 蜜臀av在线播放一区二区三区| 亚洲午夜视频| 91精品高清| 亚洲精品网址| 性色一区二区| 亚洲在线免费| 三级久久三级久久久| 日韩av不卡一区二区| 麻豆久久一区| 青青草精品视频| 亚洲ww精品| 日韩欧美激情| 国产乱码精品| 四虎精品永久免费| 免费不卡在线视频| 亚洲视频国产| 国产精品欧美大片| 久久三级毛片| 色综合五月天| 久久中文字幕av| 免费在线观看视频一区| 日韩精选在线| 国产网站在线| 女人天堂亚洲aⅴ在线观看| 免费视频亚洲| 好吊视频一区二区三区四区| 一区二区三区国产在线| 免费精品视频在线| 国产精品超碰| 99成人超碰| 久久av一区二区三区| 青草国产精品| 久久狠狠婷婷| 亚洲精品进入| 日韩高清欧美| 亚洲区第一页| 日韩国产高清在线| 天堂8中文在线最新版在线| 欧美特黄a级高清免费大片a级| 日本不卡一区二区| 成人自拍av| 日韩av中文字幕一区| 国产 日韩 欧美 综合 一区| 久久免费大视频| 国产精品嫩草影院在线看| 亚洲成av人片一区二区密柚| 日韩精品国产精品| 欧美日韩在线二区| 国产精品日本一区二区不卡视频| 久久黄色影院| 精品国产中文字幕第一页| 国产精品日韩| 久久精品青草| 精品国产精品久久一区免费式 | 日韩久久99| 亚洲成av在线| 国产精品久久国产愉拍|