React 및 Vue 프로젝트에서 SVG를 사용하는 방법
이 글은 주로 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:'absolute',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 'vue-svg-icon/Icon.vue'Vue.component('icon', 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:'absolute',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 'react-svg' ReactDOM.render( <ReactSVG path="atomic.svg" callback={svg => console.log(svg)} className="example" />, document.querySelector('.Root') )
一般都只是在使用小图标的时候才考虑 svg,而这些小图标一般都比较简约,绘制起来也没什么难度,不过大部分情况下没有必要自己来画,很多网站都提供svg的图标下载,例如阿里的 iconfont,图标数量众多,基本可以满足绝大部分的需求,另外,类似的网站还有 easyicon 、 icomoon等。
上面是我整理给大家的,希望今后会对大家有帮助。
相关文章:
如何解决vue 更改计算属性后select选中值不更改的问题,具体操作如下
위 내용은 React 및 Vue 프로젝트에서 SVG를 사용하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

AI Hentai Generator
AI Hentai를 무료로 생성하십시오.

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

뜨거운 주제











React와 WebSocket을 사용하여 실시간 채팅 애플리케이션을 구축하는 방법 소개: 인터넷의 급속한 발전과 함께 실시간 커뮤니케이션이 점점 더 주목을 받고 있습니다. 실시간 채팅 앱은 현대 사회 생활과 직장 생활에서 필수적인 부분이 되었습니다. 이 글에서는 React와 WebSocket을 사용하여 간단한 실시간 채팅 애플리케이션을 구축하는 방법을 소개하고 구체적인 코드 예제를 제공합니다. 1. 기술적 준비 실시간 채팅 애플리케이션 구축을 시작하기 전에 다음과 같은 기술과 도구를 준비해야 합니다. React: 구축을 위한 것

React 프론트엔드와 백엔드 분리 가이드: 프론트엔드와 백엔드 분리 및 독립적 배포를 달성하는 방법, 구체적인 코드 예제가 필요합니다. 오늘날의 웹 개발 환경에서는 프론트엔드와 백엔드 분리가 추세가 되었습니다. . 프런트엔드 코드와 백엔드 코드를 분리함으로써 개발 작업을 보다 유연하고 효율적으로 수행하고 팀 협업을 촉진할 수 있습니다. 이 기사에서는 React를 사용하여 프런트엔드와 백엔드 분리를 달성하고 이를 통해 디커플링 및 독립적 배포 목표를 달성하는 방법을 소개합니다. 먼저 프론트엔드와 백엔드 분리가 무엇인지 이해해야 합니다. 전통적인 웹 개발 모델에서는 프런트엔드와 백엔드가 결합되어 있습니다.

React와 Flask를 사용하여 간단하고 사용하기 쉬운 웹 애플리케이션을 구축하는 방법 소개: 인터넷의 발전과 함께 웹 애플리케이션의 요구 사항은 점점 더 다양해지고 복잡해지고 있습니다. 사용 편의성과 성능에 대한 사용자 요구 사항을 충족하기 위해 최신 기술 스택을 사용하여 네트워크 애플리케이션을 구축하는 것이 점점 더 중요해지고 있습니다. React와 Flask는 프런트엔드 및 백엔드 개발을 위한 매우 인기 있는 프레임워크이며, 함께 잘 작동하여 간단하고 사용하기 쉬운 웹 애플리케이션을 구축합니다. 이 글에서는 React와 Flask를 활용하는 방법을 자세히 설명합니다.

React 및 RabbitMQ를 사용하여 안정적인 메시징 애플리케이션을 구축하는 방법 소개: 최신 애플리케이션은 실시간 업데이트 및 데이터 동기화와 같은 기능을 달성하기 위해 안정적인 메시징을 지원해야 합니다. React는 사용자 인터페이스 구축을 위한 인기 있는 JavaScript 라이브러리인 반면 RabbitMQ는 안정적인 메시징 미들웨어입니다. 이 기사에서는 React와 RabbitMQ를 결합하여 안정적인 메시징 애플리케이션을 구축하는 방법을 소개하고 구체적인 코드 예제를 제공합니다. RabbitMQ 개요:

React 반응형 디자인 가이드: 적응형 프런트엔드 레이아웃 효과를 달성하는 방법 모바일 장치의 인기와 멀티스크린 경험에 대한 사용자 요구가 증가함에 따라 반응형 디자인은 현대 프런트엔드 개발에서 중요한 고려 사항 중 하나가 되었습니다. 현재 가장 인기 있는 프런트 엔드 프레임워크 중 하나인 React는 개발자가 적응형 레이아웃 효과를 달성하는 데 도움이 되는 풍부한 도구와 구성 요소를 제공합니다. 이 글에서는 React를 사용하여 반응형 디자인을 구현하는 데 대한 몇 가지 지침과 팁을 공유하고 참조할 수 있는 구체적인 코드 예제를 제공합니다. React를 사용한 Fle

React 코드 디버깅 가이드: 프런트엔드 버그를 빠르게 찾고 해결하는 방법 소개: React 애플리케이션을 개발할 때 애플리케이션을 충돌시키거나 잘못된 동작을 유발할 수 있는 다양한 버그에 자주 직면하게 됩니다. 따라서 디버깅 기술을 익히는 것은 모든 React 개발자에게 필수적인 능력입니다. 이 기사에서는 프런트엔드 버그를 찾고 해결하기 위한 몇 가지 실용적인 기술을 소개하고 독자가 React 애플리케이션에서 버그를 빠르게 찾고 해결하는 데 도움이 되는 특정 코드 예제를 제공합니다. 1. 디버깅 도구 선택: In Re

ReactRouter 사용자 가이드: 프런트엔드 라우팅 제어 구현 방법 단일 페이지 애플리케이션의 인기로 인해 프런트엔드 라우팅은 무시할 수 없는 중요한 부분이 되었습니다. React 생태계에서 가장 널리 사용되는 라우팅 라이브러리인 ReactRouter는 풍부한 기능과 사용하기 쉬운 API를 제공하여 프런트 엔드 라우팅 구현을 매우 간단하고 유연하게 만듭니다. 이 기사에서는 ReactRouter를 사용하는 방법을 소개하고 몇 가지 구체적인 코드 예제를 제공합니다. ReactRouter를 먼저 설치하려면 다음이 필요합니다.

React와 Google BigQuery를 사용하여 빠른 데이터 분석 애플리케이션을 구축하는 방법 소개: 오늘날 정보 폭발 시대에 데이터 분석은 다양한 산업에서 없어서는 안 될 연결 고리가 되었습니다. 그중에서도 빠르고 효율적인 데이터 분석 애플리케이션을 구축하는 것은 많은 기업과 개인이 추구하는 목표가 되었습니다. 이 기사에서는 React와 Google BigQuery를 사용하여 빠른 데이터 분석 애플리케이션을 구축하는 방법을 소개하고 자세한 코드 예제를 제공합니다. 1. 개요 React는 빌드를 위한 도구입니다.
