@AlTerminator

Как задать img источник из svg inline?

Нужно, чтобы у img src был равен изображению из svg.

<!DOCTYPE html>
<html>
 <head>
   <meta http-equiv="Content-Type" content="text/html; charset=UTF-8"> 
   <meta name="viewport" content="width=device-width, initial-scale=1.0">
 </head>
 <body onload="OnLoad()">
  <?xml version="1.0" encoding="UTF-8" standalone="no" ?><!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN" "http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd"><svg onclick="SvgLogoClick()" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" version="1.1" width="172" height="32" viewBox="0 0 172 32" xml:space="preserve"> <desc></desc> <rect x="0" y="0" width="100%" height="100%" fill="transparent"></rect> <g transform="matrix(0 0 0 0 0 0)" id="ab89e07f-1442-43df-bb69-1ec894fd456a"> </g> <g transform="matrix(1 0 0 1 86 16)" id="1fbb36a9-15d3-4ba8-b58d-3b0aa80f1c18"> <rect id="RectBG" style="stroke: none; stroke-width: 1; stroke-dasharray: none; stroke-linecap: butt; stroke-dashoffset: 0; stroke-linejoin: miter; stroke-miterlimit: 4; fill: transparent; fill-rule: nonzero; opacity: 1;" vector-effect="non-scaling-stroke"  x="-86" y="-16" rx="0" ry="0" width="172" height="32"/> </g> <g transform="matrix(0 0 0 0 0 0)"> <g> </g> </g> <g transform="matrix(0 0 0 0 0 0)"> <g> </g> </g> <g transform="matrix(0 0 0 0 0 0)"> <g> </g> </g> <g transform="matrix(0 0 0 0 0 0)"> <g> </g> </g> <g transform="matrix(0 0 0 0 0 0)"> <g> </g> </g> <g transform="matrix(0 0 0 0 0 0)"> <g> </g> </g> <g transform="matrix(0 0 0 0 0 0)"> <g> </g> </g> <g transform="matrix(0 0 0 0 0 0)"> <g> </g> </g> <g transform="matrix(0 0 0 0 0 0)"> <g> </g> </g> <g transform="matrix(0 0 0 0 0 0)"> <g> </g> </g> <g transform="matrix(0 0 0 0 0 0)"> <g> </g> </g> <g transform="matrix(0 0 0 0 0 0)"> <g> </g> </g> <g transform="matrix(0 0 0 0 0 0)"> <g> </g> </g> <g transform="matrix(0 0 0 0 0 0)"> <g> </g> </g> <g transform="matrix(0 0 0 0 0 0)"> <g> </g> </g> <g transform="matrix(0 0 0 0 0 0)"> <g> </g> </g> <g transform="matrix(0 0 0 0 0 0)"> <g> </g> </g> <g transform="matrix(0 0 0 0 0 0)"> <g> </g> </g> <g transform="matrix(0 0 0 0 0 0)"> <g> </g> </g> <g transform="matrix(0 0 0 0 0 0)"> <g> </g> </g> <g transform="matrix(0 0 0 0 0 0)"> <g> </g> </g> <g transform="matrix(0 0 0 0 0 0)"> <g> </g> </g> <g transform="matrix(0 0 0 0 0 0)"> <g> </g> </g> <g transform="matrix(0 0 0 0 0 0)"> <g> </g> </g> <g transform="matrix(0 0 0 0 0 0)"> <g> </g> </g> <g transform="matrix(0 0 0 0 0 0)"> <g> </g> </g> <g transform="matrix(0.32 0 0 0.32 15.33 16)" id="7f53d056-24ba-4c38-9fbb-39099604a94d"> 	<image style="stroke: none; stroke-width: 0; stroke-dasharray: none; stroke-linecap: butt; stroke-dashoffset: 0; stroke-linejoin: miter; stroke-miterlimit: 4; fill: #000000; fill-rule: nonzero; opacity: 1;" vector-effect="non-scaling-stroke"  xlink:href="" x="-50" y="-50" width="100" height="100"></image> </g> <g transform="matrix(0.19 0 0 0.19 101.6 16)" id="882d3729-3beb-4d12-a29d-ee9b20efa81c"> 	<text id="TextLogo" xml:space="preserve" font-family="Raleway" font-size="105" font-style="normal" font-weight="900" style="stroke: none; stroke-width: 1; stroke-dasharray: none; stroke-linecap: butt; stroke-dashoffset: 0; stroke-linejoin: miter; stroke-miterlimit: 4; fill: #000000; fill-rule: nonzero; opacity: 1; white-space: pre;" ><tspan x="-318.02" y="32.98" >ГОСТСТРОЙ</tspan></text> </g></svg>
  <img src="" alt="">
  <script>
   function OnLoad(){
      document.querySelector("img").src = ""; //Что прописать в источнике img?
   }
  </script>
 </body>
</html>
  • Вопрос задан
  • 133 просмотра
Решения вопроса 1
@AlTerminator Автор вопроса
Нужно использовать <use>
Ответ написан
Комментировать
Пригласить эксперта
Ответы на вопрос 1
NikFaraday
@NikFaraday
Student full-stack Developer
Вы можете вывести изображение в формате svg прямо а html разметку и работать с ним± как с img. Попробуйте открыть svg в любом редакторе текста/кода и перекопировать его содержимое в свой html. Так же рекоменду почитать про svg хотя бы в этой статье
Ответ написан
Ваш ответ на вопрос

Войдите, чтобы написать ответ

Похожие вопросы