成人在线亚洲_国产日韩视频一区二区三区_久久久国产精品_99国内精品久久久久久久

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

vue動態加載SVG文件并修改節點數據的操作代碼

瀏覽:182日期:2022-12-05 15:47:26

vue動態加載SVG文件并修改節點數據的操作代碼先上一個馬賽克圖片叭。

接領導需求,動態實現電路圖, 并附帶放大、縮小功能、 以及不同的回路點擊能彈窗顯示相關節點的更多信息,通俗一點講: 隨著用戶點擊放大和縮小, 點擊位置保持不變,而且能實現點擊交互。初接觸的時候,覺得根本沒法下手呀,說說自己的思路叭,

從隨著用戶點擊放大縮小位置不變,想到了SVG 但是需要動態加載進來呀,而且還需要需求不同節點的電流值, 從放大縮小來看, 首先想到的是 D3 在集合領導給的部分相關資料 綜上: 進行了可行性的方案試探,也完成了整個功能的開發。

且聽我細細道來開發遇到的問題,以及怎處理叭

SVG 在 谷歌, 以及 微軟中國,拼命的搜索,搜索出來有2個適合的組件, 大多數搜索出來的都是SVG 圖標,但是我這個需求是很大的圖片呀, 那繼續換思路, 那試著把關鍵字換成 ‘動態加載SVG 圖片’, 這樣又查出來引入SVG 圖片 可以通過 image、 Object、 embed 等等。 但是這個插入僅限于插入,并不能動態修改值, 那繼續換思路 動態加載SVG ,發現可以通過XMLHttpRequest 請求然后 添加事件、以及重新渲染DOM 元素。

那先上一段代碼

```javascript const xhr = new XMLHttpRequest(); xhr.open(’GET’, this.svgUrl, true); xhr.send(); /* 監聽xhr對象 */ xhr.onreadystatechange = function () { if (xhr.readyState == 4 && xhr.status == 200) { console.log(xhr.responseXML,’xhr.responseXML---------’) } }; xhr.addEventListener(’load’, () => { // console.log(’load’); // console.log(xhr.response,’---svg4703’) // /* 獲取 dom */ // console.log(xhr, xhr.responseXML,’xhr.responseXML’) const resXML = stringToXml(xhr.response); this.svgDom = resXML.documentElement.cloneNode(true); //this.svgDom = resXML /* 添加事件(點擊事件,鼠標滾輪事件,全屏事件) */ this.addEvents(); /* dom重置 */ this.resetDom(); /* 將svgDom對象轉換成vue的虛擬dom */ var oSerializer = new XMLSerializer(); var sXML = oSerializer.serializeToString(this.svgDom); var Profile = Vue.extend({ template: '<div id=’svgTemplate’>' + sXML + ’</div>’ }); // 創建實例,并掛載到元素上 new Profile().$mount(’#svgTemplate’); });

好,我們繼續。既然是要根據不同的用戶方,顯示出來不同的模板,那么肯定是需要遠程動態加載, 于是自己丟了一個模板到前端靜態服務器上,就開始對XMLHTTP的load 事件之后對代碼進行解析。

4.加載之后,發現又遇到一個問題了, 跨域跨域是老生常談的問題了,但是普通的請求我可以找z后端設置CORS 的允許投,那一個SVG 我表示 根本沒法下手呀, 于是我換了個思路,我們先跨域跨域,本地裝個插件如何, 最后把文件放在前端的服務器不就解決了,然后我就真的傻傻的這樣完成了,開發以及跟后端討論的過程。

5.項目經理在繼續和我溝通, 這個SVG 模板需要客戶進去上傳,也就是說,svg 文件需要專門上傳到OSS 的文件服務器上,那么我想到的第一個問題是,肯定會跨域呀, 這可咋辦呢, 急死我了,5555555…

6.當我把不同域名的SVG 文件通過XMLHTTP 引入的時候,發現SVG 圖片根本顯示不了,我不停的去切換2個文件地址。我嘗試著百度、google 發現都沒找到合適的解決方案咋辦呢, 又不能告訴項目經理說,你花了1星期的預演,之前說可以的,現在突然不行了。

7.于是我看下瀏覽器報錯在從2個方面出發。試著打印了 xhr.response

對比不顯示的代碼 跟顯示的代碼的差異點在哪里,我谷歌xml 轉為 html 打印xhr.response 的時候,發現咦 其實

xhr.response

其實是有值返回的,也就是說 其實是返回了值, 不顯示是因為

xhr.responseXML 這個值為null,

然后 `

resXML.documentElement.cloneNode(true);`沒辦法顯示,拋錯了。后續所有的操作都獲取不到任何節點。

8.然后我開始試著找怎么從XML 轉為HTML. 并且還發現真的有方法耶

//將字符串轉化成dom對象;string轉換為xmlfunction stringToXml(xmlString) { var xmlDoc; if (typeof xmlString == 'string') { //FF if (document.implementation.createDocument) { var parser = new DOMParser(); xmlDoc = parser.parseFromString(xmlString, 'text/xml'); } else if (window.ActiveXObject) { xmlDoc = new ActiveXObject('Microsoft.XMLDOM'); xmlDoc.async = false; xmlDoc.loadXML(xmlString); } } else { xmlDoc = xmlString; } return xmlDoc;} addEvents() { console.log(’這里自己寫處理代碼哈’) },resetDom() { console.log(’這里寫需要改變的節點的id 對應的值嘍’) },

整體SVG 動態加載的方案就這樣了,參考: https://www.jb51.net/article/193416.htm

我們在來看D3 , D3的話,就簡單粗暴一點 直接搜索vue D3 引用,這就不詳細說明了, 需求還是蠻多的。

還有遇到一個問題,就是全屏彈窗, 結合elementUI 使用的, 操作的時候發現點擊事件觸發了,但是彈窗并不現實,我剛開始以為是因為 z-index 的層級不夠高,然后我嘗試著瀏覽器動態調試,z-index: 99999999. 寫了一大串的9 都不顯示。

vue動態加載SVG文件并修改節點數據的操作代碼

vue動態加載SVG文件并修改節點數據的操作代碼

原來是需要全屏顯示的時候, 都需要包含在全屏的那個DIV 。

總結

到此這篇關于vue動態加載SVG文件并修改節點數據的文章就介紹到這了,更多相關vue動態加載SVG文件內容請搜索好吧啦網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持好吧啦網!

標簽: Vue
相關文章:
成人在线亚洲_国产日韩视频一区二区三区_久久久国产精品_99国内精品久久久久久久
天天色图综合网| 国产一区二区在线观看免费播放| 亚洲成人精品影院| 夜夜嗨av一区二区三区网页 | 欧美刺激脚交jootjob| 7777精品伊人久久久大香线蕉最新版| 欧美写真视频网站| 91精品国产一区二区人妖| 欧美高清视频不卡网| 日韩欧美亚洲另类制服综合在线| 欧美一级免费观看| 欧美精品一区二区三区蜜桃| 国产日韩三级在线| 亚洲美女视频在线观看| 亚洲h动漫在线| 蜜桃视频一区二区三区 | 色综合久久久久综合| 欧美吞精做爰啪啪高潮| 91精品福利在线一区二区三区| 日韩亚洲欧美高清| 国产精品免费久久久久| 一区二区三区中文字幕电影| 免费观看日韩电影| 成人黄色在线视频| 亚洲网址在线| 色一区在线观看| 日韩精品一区二区三区蜜臀| 国产精品久久久久影院色老大| 亚洲高清在线视频| 九九热在线视频观看这里只有精品| 国产mv日韩mv欧美| 激情自拍一区| 欧美亚洲自拍偷拍| 久久九九久久九九| 亚洲大型综合色站| 成人精品亚洲人成在线| 亚洲精品女人| 欧美浪妇xxxx高跟鞋交| 国产精品天干天干在线综合| 日韩精品国产精品| 91首页免费视频| 小嫩嫩精品导航| 久久综合999| 性久久久久久久久久久久| 高潮精品一区videoshd| 99av国产精品欲麻豆| 在线成人小视频| 一区二区三区中文字幕| 高清国产午夜精品久久久久久| 在线视频精品一区| 精品美女在线观看| 肉丝袜脚交视频一区二区| 99精品久久久久久| 久久亚洲一区二区| 中文字幕乱码一区二区免费| 奇米一区二区三区| 国产一区视频在线观看免费| 欧美精品久久一区| 亚洲电影第三页| 午夜精品久久99蜜桃的功能介绍| 色婷婷国产精品| 自拍偷拍国产精品| 成人免费观看视频| 欧美亚洲自拍偷拍| 亚洲精品欧美激情| 99精品视频一区二区三区| 欧美午夜理伦三级在线观看| 亚洲色图清纯唯美| 91亚洲精品一区二区乱码| 欧美日韩一卡二卡| 夜夜操天天操亚洲| 欧美天天在线| 欧美一级一区二区| 久久精品国产亚洲高清剧情介绍 | 久久亚洲影视婷婷| 国产精品白丝av| 欧美影视一区在线| 亚洲第一成年网| 999亚洲国产精| 国产精品福利在线播放| 成a人片亚洲日本久久| 91精品视频网| 精品亚洲成a人| 欧美亚洲愉拍一区二区| 亚洲第一搞黄网站| 亚洲一区二区三区高清不卡| 综合久久国产九一剧情麻豆| 欧美女人交a| 久久精品亚洲麻豆av一区二区 | 午夜精品一区二区三区电影天堂 | 欧美久久久久久久久中文字幕| 亚洲大片一区二区三区| 日韩视频久久| 亚洲欧美激情一区二区| 尤物网精品视频| 中文字幕在线观看不卡| 色综合视频一区二区三区高清| 精品美女一区二区| 成人蜜臀av电影| 欧美成人a∨高清免费观看| 国产精品1区二区.| 日韩视频一区二区在线观看| 国产精品香蕉一区二区三区| 欧美日韩五月天| 国产一区二区三区不卡在线观看 | 色欧美片视频在线观看在线视频| 亚洲韩国精品一区| 免费视频一区| 午夜精品久久久久久久久久久| 免费不卡亚洲欧美| 日韩黄色小视频| 欧美日韩在线不卡| 国产福利一区二区三区| 精品国产精品一区二区夜夜嗨| 成人av电影免费观看| 久久久不卡网国产精品二区| 色综合天天做天天爱| 成人欧美一区二区三区视频网页| 亚洲国产精品一区二区第四页av| 亚洲精品久久久蜜桃| 色综合久久久久久久久| 精品亚洲porn| 久久久久久久综合| 在线看无码的免费网站| 亚洲高清视频中文字幕| 在线视频欧美区| eeuss鲁一区二区三区| 国产精品视频第一区| 性刺激综合网| 国产一区二区免费看| 国产亚洲一区二区三区四区 | 亚洲色图视频免费播放| 久久久精品国产一区二区三区| 久久精品国产网站| 日韩欧美成人一区| 日韩视频中文| 激情五月婷婷综合| 国产精品丝袜在线| 久久精品五月婷婷| www.亚洲精品| 亚洲国产精品一区二区久久恐怖片| 欧美综合色免费| 97精品视频在线观看自产线路二| 亚洲精品伦理在线| 91精品视频网| 在线亚洲免费| 成人免费看视频| 亚洲一级片在线观看| 777午夜精品视频在线播放| 狠狠爱综合网| 国产一区二区三区四区五区入口| 18欧美乱大交hd1984| 欧美日韩精品一区二区三区四区| 亚洲欧美综合国产精品一区| 麻豆精品视频在线观看免费 | 不卡av免费在线观看| 亚洲v中文字幕| 久久影院午夜论| 在线观看欧美精品| 亚洲午夜精品国产| 成人精品视频一区二区三区尤物| 亚洲精品乱码久久久久久黑人 | 2020国产成人综合网| 一本大道久久a久久综合| 欧美在线影院| 韩国v欧美v亚洲v日本v| 一区二区三区免费网站| 欧美精品一区二区三区视频| 在线视频一区二区三| 亚洲国产一区二区三区在线播| 国产精品主播直播| 天天影视涩香欲综合网| 国产精品电影一区二区三区| 日韩精品一区二区三区中文不卡| 久久一区欧美| 国产精品美女xx| 国模 一区 二区 三区| 成人在线一区二区三区| 美女视频一区在线观看| 亚洲自拍偷拍九九九| 国产欧美久久久精品影院| 日韩欧美国产系列| 欧美三级日韩三级| 久久久久九九九| 宅男噜噜噜66一区二区 | 国产清纯美女被跳蛋高潮一区二区久久w | 亚洲国产精品一区二区www在线| 亚洲国产成人一区二区三区| 精品日韩av一区二区| 91麻豆精品国产91久久久久| 色999日韩国产欧美一区二区| 国产亚洲综合精品| 亚洲欧洲日本mm| 精品91在线| 亚洲精品日韩在线观看| 亚洲国产1区| 黄色日韩在线| 亚洲高清资源| 久久久777精品电影网影网| 日韩精品一区二区三区四区|