Как правильно встроить SVG через javascript?

Есть более десятка SVG, очень толстых SVG с множеством деталей.
Все вместе весят пару мегабайтов, соответственно их текстовый формат выглядит как полотно из текста.

Создавать спрайт из таких SVG глупо - работать с кодом неудобно, сам спрайт весит слишком много.
Значит надо динамически подгружать код, а сайт на HTML, CSS и JS - т.е. никакие php и БД не идут сюда.

Соль в том, что при проверке данных появляется попап с SVG и описанием.
И вот я сижу думаю - как максимально эффективно вставлять SVG с помощью JS?

PS: нужен именно xml формат, так как к ним будут применяться фильтры. Через img или background-image такое провернуть не получится

т.е. мне нужно примерно следующее: брать код из .svg (либо .html файла) и вставлять его на страничку. Но что-то не представляю как это. Не работал с таким никогда.
  • Вопрос задан
  • 2935 просмотров
Пригласить эксперта
Ответы на вопрос 4
tyukavin_denis
@tyukavin_denis
web developer
вставлю свои 5 копеек.
сейчас делаю мобильную версию сайта и все svg вставляю инлайново, т.к. нужно с ними взаимодействовать.
только я использую jade и вставляю их с помощью include. изначально svg чищю от мусора. да, на выходе получается полотно, но jade всё упрощает.
вы, конечно, делаете как вам удобно)
Ответ написан
Taraflex
@Taraflex
Ищу работу. Контакты в профиле.
Комментировать
Immortal_pony
@Immortal_pony Куратор тега JavaScript
Как-то так:
$('#necessary-block').load('resources/your.svg');
Ответ написан
Комментировать
@svgartru2016
Могу посоветовать такую последовательность действий:
1. Сначала очищаете от всего лишнего SVG файлы с помощью онлайн утилиты SVG-Editor автор Peter Collingridge
Убирает всё лишнее. Пользуюсь много лет. Файл становится в разы меньше, качество изображения не страдает.
2. А дальше придется ручками присвоить каждой иконке свой id=" " и класс контейнеру, в который будет обернута иконка в HTML файле.
3.Далее при помощи команд getElementById находите иконку и красите её setAttribute("fill","yellowgreen")
4. Конкретные примеры ниже в ссылках
https://jsfiddle.net/Alexandr_T/7e6yka38/
https://jsfiddle.net/Alexandr_T/c7akqwjr/
Ответ написан
Комментировать
Ваш ответ на вопрос

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

Похожие вопросы
22 нояб. 2024, в 03:54
1500 руб./за проект
22 нояб. 2024, в 02:56
10000 руб./за проект
22 нояб. 2024, в 00:55
500 руб./за проект