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

vue項(xiàng)目里面引用svg文件并給svg里面的元素賦值

 更新時(shí)間:2020年08月17日 09:56:43   作者:Miss.lang  
這篇文章主要介紹了vue項(xiàng)目里面引用svg文件并給svg里面的元素賦值,本文分步驟通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下

前言

項(xiàng)目里面用的svg圖片比較復(fù)雜,還要對(duì)里面的元素賦值等等的。在HTML里面有試著用過(guò)svg,在vue里面還是第一次嘗試。百度了很多要配置webpack.base.conf.js,還要封裝組件什么的,但是沒(méi)有用,那些方法應(yīng)該是對(duì)icon的svg或者簡(jiǎn)單的svg圖片有用吧。后面改變思路,想著能不能組件的形式引入svg文件。靜態(tài)界面下看看能不能實(shí)現(xiàn),然后在做動(dòng)態(tài)賦值。折騰了一天,還是弄出來(lái)了。真不容易,看來(lái)svg這一塊還是要好好學(xué)學(xué)的。話不多說(shuō),直接放代碼吧!

第一步:

1、先看看我們要用的svg的文件代碼,原先我是整個(gè)文件這樣子引入到vue里面,但是圖片不顯示出來(lái)。后面一步一步的檢查測(cè)試后才發(fā)現(xiàn)不能寫(xiě)有下面的這個(gè)聲明。

<?xml version="1.0" encoding="utf-8"?>
這個(gè)是xml文件聲明的,vue里面不能這樣用,至于解釋和原因,我也不懂,還是要進(jìn)一步學(xué)習(xí)研究才知道了。
<?xml version="1.0" encoding="utf-8"?>
<!-- Generator: Adobe Illustrator 16.0.0, SVG Export Plug-In . SVG Version: 6.00 Build 0) -->
<!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN" "http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd">

第二步:

東扯西扯的一堆,接下來(lái)我們看看vue里面的直接用法吧。 因?yàn)橐玫膕vg文件有好幾個(gè),但是賦值什么的方法應(yīng)該是一樣的,所以我就把js文件單獨(dú)抽出來(lái)了。順便補(bǔ)補(bǔ)svg一些元素屬性的含義。

插播:更為簡(jiǎn)單粗暴的方式就是直接用img引進(jìn)去(但是這種的話,沒(méi)有辦法給svg里面的元素賦值,只能是把svg圖片放出來(lái)展示。可能也行,只是還我不知道怎么弄)

<img src="./line.svg" alt="">

坐標(biāo)系和 viewBox

<svg> 元素的 viewBox 屬性非常重要,因?yàn)樗x了 SVG 的用戶坐標(biāo)系。簡(jiǎn)而言之,viewBox定義了用戶空間的位置和維度以便于繪制 
SVG。(可以指定 SVG 圖像的可見(jiàn)區(qū)域(viewPort))
viewBox 由四個(gè)數(shù)字組成,順序需要保持一致 —— min-x,min-y,width,height

第三步:

就是往svg里面賦值了,在單獨(dú)抽出來(lái)的js文件里面完成這些工作。簡(jiǎn)單的就是jQuery的方法了,獲取元素id,然后賦值。

var el = document.getElementById('A1');
 el.innerHTML = '1024K'; //賦值
 el.attributes.fill.value = '#FF0000'; //改變svg里面的id為A1的元素的填充顏色(背景顏色)

注意:這個(gè)id賦值,你要確保你前臺(tái)的svg文件里面的text的id跟你后臺(tái)是一樣的。(我們項(xiàng)目的svg文件是標(biāo)好了id的,然后后臺(tái)想要設(shè)置這個(gè)值的話,要根據(jù)svg里面的id來(lái)設(shè)置。)

補(bǔ)充:后臺(tái)返回svg里面的代碼的話

<template>
 <div id="bodydv" class="bodydv">
 <div style="width:100%;padding:0px;margin:0px; height: 880px; ">
  <svg id="svgInfo" height="880" version="1.1" xmlns="http://www.w3.org/2000/svg"
  xmlns:xlink="http://www.w3.org/1999/xlink" stroke-width="2" stroke="#000000" style="width:100%">
  </svg>
 </div>
 </div>
</template>
 
<script>
 var strJson = unescape(this.scene.SceneTemp); //對(duì)escape() 編碼的字符串進(jìn)行解碼。
var svg = document.getElementById('svgInfo'); //svg的id
svg.innerHTML = strJson; // svg里面的元素
var child;
 for (var i = 0; i < svg.childNodes.length; i++) {	//循壞svg里面的元素
 child = svg.childNodes[i];
 if (child.tagName == 'text' && child.id != null && child.id.length > 0) { // 判斷是不是text元素,是的話,就進(jìn)行賦值
 
 } 
 }
</script>

*** 這里要注意的是,你界面上的元素格式要如下圖

<svg id="svgInfo" height="880" version="1.1" xmlns="http://www.w3.org/2000/svg"
  xmlns:xlink="http://www.w3.org/1999/xlink" stroke-width="2" stroke="#000000" style="width:100%">
  <text transform="matrix(1 0 0 1 1110.543 530.8516)" fill="#F7F7F7" font-family="'MicrosoftYaHei'"
     font-size="14">1.00</text>
  <text transform="matrix(1 0 0 1 1111.0996 556.5186)" fill="#F7F7F7" font-family="'MicrosoftYaHei'"
     font-size="14">1.00</text>
  <text transform="matrix(1 0 0 1 1111.0996 582.1846)" fill="#F7F7F7" font-family="'MicrosoftYaHei'"
     font-size="14">1.00</text>
  <text transform="matrix(1 0 0 1 1111.0996 607.8516)" fill="#F7F7F7" font-family="'MicrosoftYaHei'"
     font-size="14">1.00</text>
 </svg>
 //如果svg里面,用 <g>,那么那個(gè)判斷child.tagName == 'text' && child.id != null,不執(zhí)行!
 <g>
  <line ></line>
  <rect x="121.228" y="65.5" fill="#0A750C" width="57.59" height="28" />
  <text id="A1" fill="#F7F7F7" font-family="'MicrosoftYaHei'" font-size="14">11.00</text>
 </g>
 ```

總結(jié)

到此這篇關(guān)于vue項(xiàng)目里面引用svg文件并給svg里面的元素賦值的文章就介紹到這了,更多相關(guān)vue引用svg文件并賦值內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Vue+OpenLayer為地圖添加風(fēng)場(chǎng)效果

    Vue+OpenLayer為地圖添加風(fēng)場(chǎng)效果

    這篇文章主要為大家展示了一個(gè)demo,即利用Vue和OpenLayer在地圖上面添加風(fēng)場(chǎng)效果,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以了解一下
    2022-04-04
  • Vue中的reactive函數(shù)操作代碼

    Vue中的reactive函數(shù)操作代碼

    這篇文章主要介紹了Vue中的reactive函數(shù),本文結(jié)合示例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2022-12-12
  • vue中拆分組件的實(shí)戰(zhàn)案例

    vue中拆分組件的實(shí)戰(zhàn)案例

    最近在學(xué)vue,試著寫(xiě)個(gè)單頁(yè)應(yīng)用,在寫(xiě)組件,拆分組件時(shí)遇到一些困惑,下面這篇文章主要給大家介紹了關(guān)于vue中拆分組件的相關(guān)資料,文中通過(guò)實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2022-12-12
  • vue引入css文件導(dǎo)致全局污染的問(wèn)題

    vue引入css文件導(dǎo)致全局污染的問(wèn)題

    這篇文章主要介紹了vue引入css文件導(dǎo)致全局污染的問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-10-10
  • 詳解vue 項(xiàng)目白屏解決方案

    詳解vue 項(xiàng)目白屏解決方案

    這篇文章主要介紹了詳解vue 項(xiàng)目白屏解決方案,詳細(xì)的介紹了白屏的解決方案,非常具有實(shí)用價(jià)值,需要的朋友可以參考下
    2018-10-10
  • 基于Vue插入視頻的2種方法小結(jié)

    基于Vue插入視頻的2種方法小結(jié)

    本文通過(guò)兩種方法給大家介紹了基于vue插入視頻的方法,每種方法通過(guò)實(shí)例代碼給大家介紹的都非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2019-04-04
  • vue使用window.open()跳轉(zhuǎn)頁(yè)面的代碼案例

    vue使用window.open()跳轉(zhuǎn)頁(yè)面的代碼案例

    這篇文章主要介紹了vue中對(duì)window.openner的使用,vue使用window.open()跳轉(zhuǎn)頁(yè)面的代碼案例,本文通過(guò)實(shí)例代碼給大家詳細(xì)講解,需要的朋友可以參考下
    2022-11-11
  • Vue監(jiān)聽(tīng)一個(gè)數(shù)組id是否與另一個(gè)數(shù)組id相同的方法

    Vue監(jiān)聽(tīng)一個(gè)數(shù)組id是否與另一個(gè)數(shù)組id相同的方法

    今天小編就為大家分享一篇Vue監(jiān)聽(tīng)一個(gè)數(shù)組id是否與另一個(gè)數(shù)組id相同的方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2018-09-09
  • vue實(shí)現(xiàn)Excel文件的上傳與下載功能的兩種方式

    vue實(shí)現(xiàn)Excel文件的上傳與下載功能的兩種方式

    這篇文章主要介紹了vue實(shí)現(xiàn)Excel文件的上傳與下載功能,本文通過(guò)兩種方式給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2019-06-06
  • vue3中使用VueParticles實(shí)現(xiàn)粒子動(dòng)態(tài)背景效果

    vue3中使用VueParticles實(shí)現(xiàn)粒子動(dòng)態(tài)背景效果

    為了提高頁(yè)面展示效果,特別類(lèi)似于登錄界面內(nèi)容比較單一的,粒子效果作為背景經(jīng)常使用到,vue工程中利用vue-particles可以很簡(jiǎn)單的實(shí)現(xiàn)頁(yè)面的粒子背景效果,本文給大家分享vue粒子動(dòng)態(tài)背景效果實(shí)現(xiàn)代碼,需要的朋友參考下吧
    2022-05-05

最新評(píng)論