2016-05-27 업데이트
React v15부터 SVG의 React에서 SVG에 대한 지원은 SVG에 대한 현재 브라우저 지원과 100 % 패리티입니다 ( source ). 이미 HTML ( class
→ className
, style="color: purple"
→ style={{color: 'purple'}}
)에 필요한 것처럼 JSX와 호환되도록 구문 변환을 적용하면됩니다 . 예를 들어 네임 스페이스가있는 (콜론으로 구분 된) 속성의 경우 속성을 xlink:href
제거 :
하고 속성의 두 번째 부분 ( 예 :)을 대문자로 만드십시오 xlinkHref
. 여기에 SVG의 예 <defs>
, <use>
그리고 인라인 스타일은 :
function SvgWithXlink (props) {
return (
<svg
width="100%"
height="100%"
xmlns="http://www.w3.org/2000/svg"
xmlnsXlink="http://www.w3.org/1999/xlink"
>
<style>
{ `.classA { fill:${props.fill} }` }
</style>
<defs>
<g id="Port">
<circle style={{fill:'inherit'}} r="10"/>
</g>
</defs>
<text y="15">black</text>
<use x="70" y="10" xlinkHref="#Port" />
<text y="35">{ props.fill }</text>
<use x="70" y="30" xlinkHref="#Port" className="classA"/>
<text y="55">blue</text>
<use x="0" y="50" xlinkHref="#Port" style={{fill:'blue'}}/>
</svg>
);
}
작업 코드 펜 데모
특정 지원에 대한 자세한 내용은 문서 의 지원되는 SVG 속성 목록을 확인하십시오 . 그리고 여기 네임 스페이스가있는 SVG 속성에 대한 지원을 추적 한 (현재 폐쇄 된) GitHub 문제 가 있습니다.
이전 답변
dangerouslySetInnerHTML
네임 스페이스 속성 만 제거하면 사용하지 않고도 간단한 SVG 임베드를 수행 할 수 있습니다 . 예를 들어, 다음과 같이 작동합니다.
render: function() {
return (
<svg viewBox="0 0 120 120">
<circle cx="60" cy="60" r="50"/>
</svg>
);
}
이 시점에서과 같은 소품을 추가 fill
하거나 구성하는 데 유용한 다른 것을 추가 할 수 있습니다.
<svg id="Layer_1">
(또는 id없이 더 좋게) 변경하는 것이 간단 할 수 있습니다 . 편집 : 여기 예입니다 : jsbin.com/nifemuwi/2/edit?js,output