欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

vue動(dòng)態(tài)加載SVG文件并修改節(jié)點(diǎn)數(shù)據(jù)的操作代碼

 更新時(shí)間:2020年08月17日 10:02:11   作者:weixin_43988317  
這篇文章主要介紹了vue動(dòng)態(tài)加載SVG文件并修改節(jié)點(diǎn)數(shù)據(jù)的方法,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下

在這里插入圖片描述
先上一個(gè)馬賽克圖片叭。

接領(lǐng)導(dǎo)需求,動(dòng)態(tài)實(shí)現(xiàn)電路圖, 并附帶放大、縮小功能、 以及不同的回路點(diǎn)擊能彈窗顯示相關(guān)節(jié)點(diǎn)的更多信息,
通俗一點(diǎn)講: 隨著用戶點(diǎn)擊放大和縮小, 點(diǎn)擊位置保持不變,而且能實(shí)現(xiàn)點(diǎn)擊交互。
初接觸的時(shí)候,覺得根本沒法下手呀,說說自己的思路叭,

  • 從隨著用戶點(diǎn)擊放大縮小位置不變,想到了SVG 但是需要?jiǎng)討B(tài)加載進(jìn)來呀,而且還需要需求不同節(jié)點(diǎn)的電流值,
  • 從放大縮小來看, 首先想到的是 D3
  • 在集合領(lǐng)導(dǎo)給的部分相關(guān)資料
  • 綜上: 進(jìn)行了可行性的方案試探,也完成了整個(gè)功能的開發(fā)。

且聽我細(xì)細(xì)道來開發(fā)遇到的問題,以及怎處理叭

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

那先上一段代碼

```javascript
 const xhr = new XMLHttpRequest();
 xhr.open('GET', this.svgUrl, 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', () => {
 // 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
 /* 添加事件(點(diǎn)擊事件,鼠標(biāo)滾輪事件,全屏事件) */
 this.addEvents();
 /* dom重置 */
 this.resetDom();
 /* 將svgDom對象轉(zhuǎn)換成vue的虛擬dom */
 var oSerializer = new XMLSerializer();
 var sXML = oSerializer.serializeToString(this.svgDom);
 var Profile = Vue.extend({
  template: "<div id='svgTemplate'>" + sXML + '</div>'
 });
 // 創(chuàng)建實(shí)例,并掛載到元素上
 new Profile().$mount('#svgTemplate');
 });

好,我們繼續(xù)。
既然是要根據(jù)不同的用戶方,顯示出來不同的模板,那么肯定是需要遠(yuǎn)程動(dòng)態(tài)加載, 于是自己丟了一個(gè)模板到前端靜態(tài)服務(wù)器上,就開始對XMLHTTP的load 事件之后對代碼進(jìn)行解析。

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

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

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

7.于是我看下瀏覽器報(bào)錯(cuò)在從2個(gè)方面出發(fā)。試著打印了 xhr.response

  1. 對比不顯示的代碼 跟顯示的代碼的差異點(diǎn)在哪里,我谷歌xml 轉(zhuǎn)為 html
  2. 打印xhr.response 的時(shí)候,發(fā)現(xiàn)咦 其實(shí)

xhr.response

其實(shí)是有值返回的,也就是說 其實(shí)是返回了值, 不顯示是因?yàn)?/p>

xhr.responseXML 這個(gè)值為null,

然后 `

resXML.documentElement.cloneNode(true);
`
沒辦法顯示,拋錯(cuò)了。后續(xù)所有的操作都獲取不到任何節(jié)點(diǎn)。

8.然后我開始試著找怎么從XML 轉(zhuǎn)為HTML. 并且還發(fā)現(xiàn)真的有方法耶

//將字符串轉(zhuǎn)化成dom對象;string轉(zhuǎn)換為xml
function 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('這里寫需要改變的節(jié)點(diǎn)的id 對應(yīng)的值嘍') 
},

整體SVG 動(dòng)態(tài)加載的方案就這樣了,
參考: http://www.dbjr.com.cn/article/193416.htm

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

還有遇到一個(gè)問題,就是全屏彈窗, 結(jié)合elementUI 使用的, 操作的時(shí)候發(fā)現(xiàn)點(diǎn)擊事件觸發(fā)了,但是彈窗并不現(xiàn)實(shí),
我剛開始以為是因?yàn)?z-index 的層級不夠高,然后我嘗試著瀏覽器動(dòng)態(tài)調(diào)試,z-index: 99999999. 寫了一大串的9 都不顯示。

在這里插入圖片描述

在這里插入圖片描述

原來是需要全屏顯示的時(shí)候, 都需要包含在全屏的那個(gè)DIV 。

總結(jié)

到此這篇關(guān)于vue動(dòng)態(tài)加載SVG文件并修改節(jié)點(diǎn)數(shù)據(jù)的文章就介紹到這了,更多相關(guān)vue動(dòng)態(tài)加載SVG文件內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Vue核心概念A(yù)ction的總結(jié)

    Vue核心概念A(yù)ction的總結(jié)

    今天小編就為大家分享一篇關(guān)于Vue核心概念A(yù)ction的總結(jié),小編覺得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來看看吧
    2019-01-01
  • 前端開發(fā)指南之vue-grid-layout的使用實(shí)例

    前端開發(fā)指南之vue-grid-layout的使用實(shí)例

    vue-grid-layout是一個(gè)vue柵格拖動(dòng)布局的組件,下面這篇文章主要給大家介紹了關(guān)于前端開發(fā)指南之vue-grid-layout使用的相關(guān)資料,文中通過實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2022-09-09
  • Vue之el-select結(jié)合v-if動(dòng)態(tài)控制template顯示隱藏方式

    Vue之el-select結(jié)合v-if動(dòng)態(tài)控制template顯示隱藏方式

    這篇文章主要介紹了Vue之el-select結(jié)合v-if動(dòng)態(tài)控制template顯示隱藏方式,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-04-04
  • vue+echarts實(shí)現(xiàn)進(jìn)度條式柱狀圖

    vue+echarts實(shí)現(xiàn)進(jìn)度條式柱狀圖

    這篇文章主要為大家詳細(xì)介紹了vue+echarts實(shí)現(xiàn)進(jìn)度條式柱狀圖,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-09-09
  • Vue使用Clipboard.JS在h5頁面中復(fù)制內(nèi)容實(shí)例詳解

    Vue使用Clipboard.JS在h5頁面中復(fù)制內(nèi)容實(shí)例詳解

    在本篇文章里小編給大家整理了關(guān)于Vue使用Clipboard.JS在h5頁面中復(fù)制內(nèi)容以及相關(guān)知識點(diǎn)內(nèi)容,需要的朋友們可以學(xué)習(xí)下。
    2019-09-09
  • 關(guān)于vue2強(qiáng)制刷新,解決頁面不會重新渲染的問題

    關(guān)于vue2強(qiáng)制刷新,解決頁面不會重新渲染的問題

    今天小編就為大家分享一篇關(guān)于vue2強(qiáng)制刷新,解決頁面不會重新渲染的問題,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-10-10
  • vue實(shí)現(xiàn)token過期自動(dòng)跳轉(zhuǎn)到登錄頁面

    vue實(shí)現(xiàn)token過期自動(dòng)跳轉(zhuǎn)到登錄頁面

    本文主要介紹了vue實(shí)現(xiàn)token過期自動(dòng)跳轉(zhuǎn)到登錄頁面,文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-10-10
  • Vue路由守衛(wèi)之路由獨(dú)享守衛(wèi)

    Vue路由守衛(wèi)之路由獨(dú)享守衛(wèi)

    這篇文章主要介紹了Vue路由守衛(wèi)之路由獨(dú)享守衛(wèi)的代碼,非常不錯(cuò),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2019-09-09
  • 深入了解vue-loader是如何工作的

    深入了解vue-loader是如何工作的

    這篇文章主要為大家詳細(xì)介紹了vue-loader的工作原理與使用,文中的示例代碼講解詳細(xì),具有一定的借鑒價(jià)值,感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下
    2023-12-12
  • vue中對接Graphql接口的實(shí)現(xiàn)示例

    vue中對接Graphql接口的實(shí)現(xiàn)示例

    本文主要介紹了vue中對接Graphql接口的實(shí)現(xiàn)示例,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-05-05

最新評論