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

您的位置:首頁技術文章
文章詳情頁

Vue.js中動態更改svg的相關屬性詳解

瀏覽:30日期:2022-06-02 08:54:37
目錄
  • 引言
  • 怎樣將一個遠程的svg圖標資源"下載"到本地
  • 怎樣更改svgdom結構里面的相關屬性

引言

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

怎樣將一個遠程的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對象 */      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對象轉換成vue的虛擬dom,代碼如下: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");      });    },

以上就是Vue.js中動態更改svg的相關屬性詳解的詳細內容,更多關于Vue.js動態更改svg屬性的資料請關注其它相關文章!

標簽: JavaScript
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
国产欧美日韩视频在线| 亚洲婷婷丁香| 国产精品一区二区精品视频观看| 综合激情网...| 亚洲在线免费| 91成人精品视频| 欧美日韩国产精品一区二区亚洲| 欧美不卡高清| 国产高清一区二区| 影音国产精品| 日韩一区精品视频| 日韩中文av| 欧美精品中文字幕亚洲专区| 国产精品综合色区在线观看| 免费一区二区三区在线视频| 久久久精品国产**网站| 日韩成人精品一区| 九九久久电影| 天使萌一区二区三区免费观看| 中文字幕av一区二区三区人| 国产亚洲字幕| 国产欧美日韩一区二区三区四区 | 日韩精品亚洲专区在线观看| 欧美私人啪啪vps| 国产精品s色| 在线天堂资源www在线污| 99精品美女| 香蕉视频成人在线观看| 欧美一级网站| 日韩在线视频精品| 亚洲欧美日韩国产| 日韩精品视频一区二区三区| 久久99蜜桃| 久久国产中文字幕| 日韩一区二区三区精品| 免费亚洲婷婷| 婷婷亚洲五月色综合| 91精品国产自产观看在线 | 日韩大片在线播放| 亚洲美洲欧洲综合国产一区| 日本色综合中文字幕| 伊人久久视频| 99视频在线精品国自产拍免费观看| 天堂俺去俺来也www久久婷婷| 国产一区调教| 性欧美长视频| 成人在线视频免费看| 99在线|亚洲一区二区| 国产激情久久| 午夜久久美女| 毛片不卡一区二区| 激情91久久| 国产精品videosex极品| 欧美女激情福利| 久久一区亚洲| 久久国产福利| 国产成人调教视频在线观看| 99国产成+人+综合+亚洲欧美| 国产精品久久久久77777丨 | 午夜在线精品| 国产精品99一区二区三| 男女男精品视频网| 日韩av在线中文字幕| 综合在线一区| 久久精品青草| 国产精品mm| 亚洲欧美日本视频在线观看| 日韩av有码| 久久国产麻豆精品| 在线综合亚洲| 国产一区二区三区久久久久久久久| 日韩一区欧美二区| 欧美久久香蕉| 超碰成人av| 天堂资源在线亚洲| 丝袜诱惑制服诱惑色一区在线观看| 成人羞羞在线观看网站| 久久麻豆视频| 日日摸夜夜添夜夜添国产精品| 欧美成人a交片免费看| 伊人精品久久| 亚洲香蕉久久| 快播电影网址老女人久久| 天堂精品久久久久| 日韩亚洲国产欧美| 国产精品成人a在线观看| 日韩精品免费视频人成| 99国产精品99久久久久久粉嫩| 国产一区二区三区久久| 国产精品男女| 日韩精品91亚洲二区在线观看| 亚洲专区欧美专区| 婷婷综合在线| 香蕉久久精品| 极品裸体白嫩激情啪啪国产精品| 久久精品国产99国产| 亚洲欧美日韩综合国产aⅴ| 国产夫妻在线| 精品国产亚洲一区二区三区在线| 亚洲综合三区| 7777精品| 久久99伊人| 亚洲国产不卡| 秋霞影院一区二区三区| 精品国产一区二区三区性色av| 少妇精品在线| 国产亚洲永久域名| 性欧美69xoxoxoxo| 伊人精品一区| 999久久久国产精品| 欧美精选视频一区二区| 国产高潮在线| www.九色在线| 国产精品久久久久毛片大屁完整版| 国产+成+人+亚洲欧洲在线| 国产欧美一区| 乱人伦精品视频在线观看| 99国产精品久久久久久久成人热| 久久网站免费观看| 99久久久久久中文字幕一区| 精品久久影院| 大香伊人久久精品一区二区 | 中文字幕av亚洲精品一部二部 | 中文字幕在线官网| 日韩毛片视频| 成人片免费看| 亚洲成av在线| 蜜桃tv一区二区三区| 欧美1区免费| 午夜久久tv| 日韩在线一区二区| 亚洲精品进入| 91p九色成人| 免费一级欧美在线观看视频| 久久xxx视频| 久久久久久自在自线| 999国产精品| 99热精品在线| 亚洲精选91| 国产精品网在线观看| 精品久久97| www.九色在线| 99热精品久久| 在线亚洲自拍| 日本aⅴ精品一区二区三区| 久久国产乱子精品免费女| 欧美黑人巨大videos精品| 国产在线一区不卡| 91精品国产91久久久久久黑人| 妖精视频成人观看www| 亚洲精品自拍| 麻豆国产欧美日韩综合精品二区| 国产精品久久久久久久免费观看 | 石原莉奈在线亚洲三区| 日韩高清国产一区在线| 久久精品国产99国产| 九九色在线视频| 夜夜嗨av一区二区三区网站四季av| 亚洲婷婷丁香| 国产精品久久久免费| 国产拍在线视频| 亚洲精品在线观看91| 日韩高清三区| 国产精品www.| 久久国产直播| 中文无码久久精品| 国产欧美在线| 亚洲成人av观看| 亚洲一级大片| 久久精品国产成人一区二区三区| 成人羞羞视频播放网站| 国产精品日本欧美一区二区三区| 日本一区免费网站| 国产精品99一区二区三| 免费欧美日韩| 蜜桃精品视频| 欧美另类综合| 国产伦精品一区二区三区视频| 国产精品成人a在线观看| 99亚洲视频| 国产精品超碰| 伊人久久亚洲热| 国产精品亚洲综合色区韩国| 久久久777| 国产精品一区二区99| 久久美女性网| 亚洲精品在线二区| 国产一区二区三区四区五区| 影院欧美亚洲| 精品女同一区二区三区在线观看| 国产专区一区| 国产精品久久久久久av公交车| 欧美日韩国产传媒| 91麻豆精品激情在线观看最新| 日韩欧美中文| 日韩精品久久久久久| 亚洲婷婷在线| 美女精品久久| 三级在线观看一区二区| 国产一区二区三区日韩精品|