>웹 프론트엔드 >JS 튜토리얼 >React 및 Vue 프로젝트에서 SVG를 사용하는 방법

React 및 Vue 프로젝트에서 SVG를 사용하는 방법

亚连
亚连원래의
2018-06-06 15:24:092182검색

이 글은 주로 React와 Vue 프로젝트에서 SVG를 사용하는 방법을 소개하고 있습니다. 이제 참고용으로 공유하겠습니다.

일부 최신 플랫 디자인 웹사이트, 특히 모바일 웹사이트에는 웹사이트 아이콘, 사용자 기본 아바타, 모바일 홈 페이지 하단의 고정 전환 막대 등과 같이 간단하고 명확한 작은 아이콘이 많이 포함되어 있는 경우가 많습니다. 이러한 작은 아이콘 아이콘은 일반적으로 아티스트가 만든 것으로 스프라이트 차트에 배치한 다음 잘라서 프런트 엔드에 표시할 수 있습니다.

사실 아티스트가 이렇게 간단한 작은 아이콘을 만들 필요는 없습니다. 프런트 엔드에서는 svg를 사용하여 이러한 간단한 아이콘을 그릴 수 있으며 이러한 아이콘은 코드로 설명되어 있으므로 수정하고 싶다면 아이콘 색상, 아이콘 모양, 크기 등을 변경하는 작업은 코드 몇 줄만 변경하면 매우 간단하며 아트를 다시 작업할 필요가 없습니다.

이 글에서는 svg를 사용하여 그림을 그리는 방법을 설명하지 않습니다. svg를 모른다면 여기로 가서 웹사이트에서 svg를 사용하는 방법에 대해 주로 설명합니다.

일반 웹 페이지에서 SVG 사용

svg는 XML 형식을 사용하여 이미지를 정의하며 웹 페이지에 삽입되어 특정 효과를 나타내는 일반적인 HTML 태그라고 생각할 수도 있습니다. 웹 페이지에서 svg 사용 예는 다음과 같습니다.

<body>
  <svg width="100" height="100" version="1.1" xmlns="http://www.w3.org/2000/svg">
    <rect width="100%" height="100%" style="fill:pink;stroke-width:1;stroke:rgb(0,0,0)"/>
  </svg></body>

효과는 다음과 같습니다.

보시다시피 일반 웹 페이지에서 svg를 사용하는 것은 매우 간단합니다. 웹페이지에서 렌더링하는 것은 전혀 문제가 되지 않습니다.

Vue에서 Svg 사용

일반 웹 페이지에서 svg를 사용하는 것처럼 Vue에서도 svg를 사용할 수 있습니다. 그러나 컴포넌트 개발 프로젝트로 vue를 선택했기 때문에 여러 컴포넌트 중에서 결국에는 긴 svg는 약간 보기 흉합니다.

한 가지 해결책은 svg의 use 태그를 사용하는 것입니다. 메인 페이지에 svg 아이콘을 그리는 코드를 직접 작성하는 대신 이 큰 코드 섹션을 다른 파일에 넣은 다음 use를 사용하여 이 코드를 참조하세요. 아이콘만으로도 충분합니다(Ele.me 모바일 단말기가 이런 역할을 하는 것 같습니다).

예를 들어 svg를 그리기 위한 모든 코드를 svg-icon.vue 파일에 넣으세요. 기호 태그를 사용하여 모든 아이콘에 대한 그리기 코드를 구분하고 별도로 이름을 지정하여 혼동을 방지하세요. 그런 다음 이 파일을 컴포넌트로 내보내서 표시하세요. 홈 페이지에서 이 구성 요소를 페이지에 소개한 다음 svg 아이콘을 사용해야 하는 곳에 use 태그를 통해 소개합니다.

svg-draw.vue 코드 예는 다음과 같습니다.

<template>
 <svg
  xmlns="http://www.w3.org/2000/svg"
  xmlnsXlink="http://www.w3.org/1999/xlink"
  style={{position:&#39;absolute&#39;,width:0,height:0}}>
  <defs>
   <symbol viewBox="0 0 26 31" id="location">
    <path xmlns="http://www.w3.org/2000/svg" d="M512.571517 65.907059c-204.736964 0-370.715183 165.979242-370.715183 370.724393 0 94.440929 35.320437 180.625824 93.462648 246.083651 1.572822 2.690272 3.50994 5.225001 5.817496 7.531534l240.297878 251.597225c1.279133 1.864464 2.736321 3.64297 4.393054 5.298679 2.111081 2.111081 4.418636 3.90596 6.856152 5.402033 14.458293 10.06524 34.491559 8.658194 47.393403-4.242627 3.26537-3.263323 5.78782-6.987135 7.582699-10.960633L783.610536 690.24766c1.867534-1.866511 3.489474-3.88447 4.876054-6.010901 58.951647-65.640999 94.819552-152.431691 94.819552-247.604284C883.305119 231.886301 717.325877 65.907059 512.571517 65.907059zM512.390391 588.611865c-82.734306 0-149.814074-67.087954-149.814074-149.842727 0-82.753749 67.079768-149.833517 149.814074-149.833517 82.772168 0 149.851936 67.079768 149.851936 149.833517C662.242328 521.523911 595.161536 588.611865 512.390391 588.611865z" fill="#d81e06"/>
   </symbol>
  </defs>
 </svg></template>

전체 vue 구성 요소는 큰 svg를 내보냅니다. 이 svg에는 스프라이트 차트와 유사한 많은 작은 아이콘이 포함되어 있으며 편의상 개별적으로 이름이 지정됩니다. .

사용 예는 다음과 같습니다.

// index.vue
...<svg class="location-icon">
 <use xlink:href="#location" rel="external nofollow" ></use></svg>...

그러면 해당 svg 아이콘이 웹 페이지에 성공적으로 나타나는 것을 볼 수 있습니다.

그러나 현재 웹 사이트에서 많은 양을 사용해야 하는 경우 여전히 문제가 있습니다. 결과적으로 svg-icon.vue의 파일 크기는 점차 커집니다. 현재 웹 페이지 이름을 지정하는 데 svg 아이콘 중 하나만 필요합니다. 결과적으로 svg 코드를 모두 로드하게 됩니다. 수백 개의 아이콘이 있습니다. 이는 현재 웹 페이지에 필요한 아이콘을 로드하는 것을 의미하므로 그다지 친숙하지 않습니다. . 나타날 기회가 없으면 로드되지 않습니다.

Github에는 그런 플러그인이 많이 있습니다. 제가 생각하기에 매우 유용하다고 생각되는 플러그인은 사용하기 쉽고 빠르게 시작할 수 있는 vue-svg-icon입니다.

먼저 이 플러그인을 설치하세요. 설치가 완료된 후 프로젝트의 항목 파일에 이 플러그인을 등록하면 글로벌 호출이 용이해집니다.

import Icon from &#39;vue-svg-icon/Icon.vue&#39;Vue.component(&#39;icon&#39;, Icon)

그런 다음 새 svg 디렉터리를 만듭니다. 루트 디렉터리의 /src 디렉터리(현재 이 경로는 이 경로만 가능하며 다른 경로 및 디렉터리로 구성할 수 없음)를 선택한 다음 이 디렉터리에 사용하려는 svg 아이콘의 svg 파일을 넣습니다.

예를 들어 WeChat 아이콘의 svg는 다음과 같습니다.

<?xml version="1.0" standalone="no"?>
<!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN" "http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd">
<svg t="1502683891821" class="icon" style="" viewBox="0 0 1024 1024" version="1.1" xmlns="http://www.w3.org/2000/svg" p-id="2885" xmlns:xlink="http://www.w3.org/1999/xlink" width="16" height="16">
<defs>
<style type="text/css"></style>
</defs>
<path d="M282.6 363.8c-23.7 0-47-15.7-47-38.9 0-23.7 23.3-38.9 46.5-38.9 23.7 0 38.9 15.2 38.9 38.9 0.5 23.2-15.1 38.9-38.4 38.9zM500.4 286c23.7 0 38.9 15.2 38.9 38.9 0 23.3-15.2 38.9-38.9 38.9-23.3 0-47-15.7-47-38.9 0-23.7 23.7-38.9 47-38.9z m167.7 84.5c9.8 0 19.7 0.5 30 1.8-27.3-125.6-161.4-218.7-314.4-218.7C212.4 153.6 72 270.3 72 418.3c0 85.9 46.5 155.6 124.8 210.2l-31.3 93.9 109.1-54.6c38.9 7.6 70.2 15.7 109.1 15.7 9.4 0 19.2-0.5 29.1-1.3-6.3-20.6-9.8-42.9-9.8-65.3-0.1-136 116.6-246.4 265.1-246.4z" p-id="2886"></path><path d="M772.7 573.9c-15.2 0-30.9-15.2-30.9-30.9 0.5-15.7 15.7-31.3 30.9-31.3 23.7 0 39.4 15.7 39.4 31.3-0.1 15.7-15.7 30.9-39.4 30.9z m-171.3 0c-15.2 0-30.9-15.2-30.9-30.9s15.7-31.3 30.9-31.3c23.7 0 38.9 15.7 38.9 31.3 0.5 15.7-15.2 30.9-38.9 30.9zM952 613.3C952 488.5 827.2 387 687.3 387c-148 0-264.7 101.5-264.7 226.3 0 124.8 116.7 225.8 264.7 225.8 31.3 0 62.6-8.1 93.5-15.7l85.9 47-23.7-77.8c62.5-47 109-109.1 109-179.3z" p-id="2887">
</path>
</svg>

위 코드를 wx.svg와 같은 .svg 파일에 저장하고 /src/svg 디렉터리에 넣으면 준비 작업이 완료됩니다. .

다음으로 사용하고 싶다면 매우 간단합니다. vue 구성 요소에 직접 작성하면 됩니다.

<template>
  <icon class="wx-icon" name="wx"></icon></template>

페이지를 새로 고칠 때 콘솔을 열면 wx.svg 파일을 볼 수 있습니다. 이런 식으로 svg 파일의 주문형 도입이 구현되었습니다.

React에서 Svg 사용

React에서 Svg를 사용하는 것은 vue와 동일합니다. 또한 세 가지 해결 방법이 있습니다. 하나는 React의 리더 방식에서 직접 svg 코드를 작성하는 것이고, 두 번째는 모든 svg Put을 그리는 것입니다. 코드를 파일에 넣은 다음 파일을 한 번 로드하고 use 태그를 사용하여 해당 svg 패턴을 참조합니다. 세 번째 방법은 플러그인을 사용하여 요청 시 도입하는 것입니다.

第一种直接在 渲染方法中写入 svg的方法就不多说了,第二种也很简单 ,和 vue一样,只不过写法上需要注意一下。

render() {
  return (
   <svg
    xmlns="http://www.w3.org/2000/svg"
    xmlnsXlink="http://www.w3.org/1999/xlink"
    style={{position:&#39;absolute&#39;,width:0,height:0}}>
    <defs>
     <symbol viewBox="0 0 26 31" id="location">
      <path fill="#FFF" fillRule="evenodd" d="M22.116 22.601c-2.329 2.804-7.669 7.827-7.669 7.827-.799.762-2.094.763-2.897-.008 0 0-5.26-4.97-7.643-7.796C1.524 19.8 0 16.89 0 13.194 0 5.908 5.82 0 13 0s13 5.907 13 13.195c0 3.682-1.554 6.602-3.884 9.406zM18 13a5 5 0 1 0-10 0 5 5 0 0 0 10 0z"></path>
     </symbol>
     <symbol viewBox="0 0 14 8" id="arrow">
      <path fill="#FFF" fillRule="evenodd" d="M5.588 6.588c.78.78 2.04.784 2.824 0l5.176-5.176c.78-.78.517-1.412-.582-1.412H.994C-.107 0-.372.628.412 1.412l5.176 5.176z"></path>
     </symbol>
    </svg>
   )
}

主要是需要注意,因为 react使用 jsx语法,不允许出现 - 连字符,所以像 fill-rule这样的属性,就必须写成 fillRule,引用的时候同样如此。

// 引用的时候需要将 `xlink:href` 改写成 xlinkHref<svg className="arrow-left">
  <use xlinkhref="#arrow-left" rel="external nofollow" ></use>
 </svg>

第三种按需引入,只加载当前需要的 svg形状,同样是将每一个 svg图片作为一个单独的文件保存,然后再需要使用的地方进行引用。 Github上有个项目 react-svg,这个项目内部其实是对 SVGInjector的包装,

安装 react-svg之后,就可以像下面这样使用了:

import ReactSVG from &#39;react-svg&#39;

ReactDOM.render(
 <ReactSVG
  path="atomic.svg"
  callback={svg => console.log(svg)}
  className="example"
 />,
 document.querySelector(&#39;.Root&#39;)
)

一般都只是在使用小图标的时候才考虑 svg,而这些小图标一般都比较简约,绘制起来也没什么难度,不过大部分情况下没有必要自己来画,很多网站都提供svg的图标下载,例如阿里的 iconfont,图标数量众多,基本可以满足绝大部分的需求,另外,类似的网站还有 easyicon 、 icomoon等。

上面是我整理给大家的,希望今后会对大家有帮助。

相关文章:

有关在Vue中使用Compass的具体方法?

如何关闭Vue计算属性自带的缓存功能,具体步骤有哪些?

如何解决vue 更改计算属性后select选中值不更改的问题,具体操作如下

위 내용은 React 및 Vue 프로젝트에서 SVG를 사용하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.