SVG: динамически созданный <use> не будет отображаться

Я динамически создаю серию кругов, используя SVG.
Код создает действительную модель DOM, что вы можете проверить в окне разработчика браузера.

Но круги не отображаются ...
Только после изменения чего-то в svg-коде в DOM в окне разработчика кружки отображаются.

Вот мой код. Надеюсь, это не требует пояснений. Я переработал свой исходный код до самой сути.

(Никаких решений jQuery, пожалуйста.)

HTML:

<!doctype html>
<html>
    <head>
        <meta charset = "utf-8" />
        <title>svg</title>
    </head>
    <body>
        <div id = "test"></div>
        <script>
TOOLTIPS = [
  { "x": 100, "y": 100 },
  { "x": 200, "y": 200 }
];

(function () {
var obj = document.createElement('object');
obj.type = 'image/svg+xml';
obj.data = 'test.svg';
obj.onload = function () {
    TOOLTIPS.forEach(function (index) {
        var svgDoc = document.getElementsByTagName('object')[0].contentDocument;
        var svgRoot = svgDoc.documentElement;
        var group = svgRoot.getElementById('layer1');
        var use = svgDoc.createElementNS('http://www.w3.org/2000/svg', 'use');

        use.setAttribute('xlink:href', '#blue');
        use.setAttribute('transform', 'translate(' + index.x + ' ' + index.y + ')');

        group.appendChild(use);
    });
};
document.getElementById('test').appendChild(obj);
})();
    </script>
</body>

SVG ('test.svg'):

<svg id = "svgBody" xmlns = "http://www.w3.org/2000/svg" xmlns:xlink = "http://www.w3.org/1999/xlink" viewBox = "0 0 1366 768">
  <defs>
    <circle id = "blue" style = "fill: #00f" cx = "12.5" cy = "12.5" r = "8" />
  </defs>
  <g id = "layer1"></g>
</svg>

Мне любопытно, почему вы здесь используете <object>. Почему бы просто не сделать это встроенным в основной HTML-файл?

Paul LeBeau 24.07.2018 11:57

Используйте setAttributeNS для создания элемента xlink: href и убедитесь, что вы указали пространство имен xlink в качестве первого аргумента.

Robert Longson 24.07.2018 11:59
use.setAttributeNS('http://www.w3.org/1999/xlink', 'xlink:href', '#blue');
Paul LeBeau 24.07.2018 12:11

Также имейте в виду, что в Chrome contentDocument не будет работать (он всегда будет нулевым), если вы загружаете тестовый файл HTML из локальной файловой системы (например, file://). См .: stackoverflow.com/questions/5333878/…. Если это ваш случай, запустите локальный веб-сервер или используйте Firefox для тестирования.

Paul LeBeau 24.07.2018 12:13

БЛАГОДАРНОСТЬ! У меня создалось впечатление, что в данном случае setAttributeNS мне не нужен, но, очевидно, я ошибался. @Paul LeBeau, спасибо за предупреждение о contentDocument.

Dick 24.07.2018 13:17
Поведение ключевого слова "this" в стрелочной функции в сравнении с нормальной функцией
Поведение ключевого слова "this" в стрелочной функции в сравнении с нормальной функцией
В JavaScript одним из самых запутанных понятий является поведение ключевого слова "this" в стрелочной и обычной функциях.
Концепция локализации и ее применение в приложениях React ⚡️
Концепция локализации и ее применение в приложениях React ⚡️
Локализация - это процесс адаптации приложения к различным языкам и культурным требованиям. Это позволяет пользователям получить опыт, соответствующий...
Улучшение производительности загрузки с помощью Google Tag Manager и атрибута Defer
Улучшение производительности загрузки с помощью Google Tag Manager и атрибута Defer
В настоящее время производительность загрузки веб-сайта имеет решающее значение не только для удобства пользователей, но и для ранжирования в...
Безумие обратных вызовов в javascript [JS]
Безумие обратных вызовов в javascript [JS]
Здравствуйте! Юный падаван 🚀. Присоединяйся ко мне, чтобы разобраться в одной из самых запутанных концепций, когда вы начинаете изучать мир...
Система управления парковками с использованием HTML, CSS и JavaScript
Система управления парковками с использованием HTML, CSS и JavaScript
Веб-сайт по управлению парковками был создан с использованием HTML, CSS и JavaScript. Это простой сайт, ничего вычурного. Основная цель -...
JavaScript Вопросы с множественным выбором и ответы
JavaScript Вопросы с множественным выбором и ответы
Если вы ищете платформу, которая предоставляет вам бесплатный тест JavaScript MCQ (Multiple Choice Questions With Answers) для оценки ваших знаний,...
0
5
30
0

Другие вопросы по теме