Задать вопрос
@z0ddak
Мордор напоминает о себе

Ошибка объявления функции в svg — FireBug Mozilla. Как обойти?

Использую вот такую конструкцию для динамической смены значений в SVG-файле:

<?xml version="1.0" encoding="utf-8"?>
<svg version="1.1" 
		viewBox="0 0 200 100" 
		preserveAspectRatio="xMidYMid meet" 
		onload="svgload_svg(evt);" 
		xmlns:xlink="http://www.w3.org/1999/xlink" 
		xmlns:ev="http://www.w3.org/2001/xml-events" 
		xmlns="http://www.w3.org/2000/svg">

<defs>
<script type="application/ecmascript"><![CDATA[
function svgload_svg(evt) {

  var w = window, w0 = null;
  while (w && !w.svgload_html && w != w0) {
    w0 = w;
    w = w.parent;
  }
  if (w)

  // вот на эту строку ссылается Mozilla, считая её ошибочной
  w.svgload_html(evt);
}
]]></script>
</defs>

<rect id="fig1" x="10" y="10" width="80" height="80" fill="red" stroke="black" stroke-width="10" />
<circle id="fig2" cx="150" cy="50" r="40" fill="black" stroke="red" stroke-width="10" />
</svg>


window.svgload_html = function(evt) {
  var svg = evt.target, //Вот он, корневой узел DOM SVG
      f = false, fig1 = svg.getElementById("fig1"), fig2 = svg.getElementById("fig2");
  setInterval(function() {
    f = !f;
    fig1.attributes["fill"].value = f ? "black" : "red";
    fig1.attributes["stroke"].value = f ? "red" : "black";
    fig2.attributes["fill"].value = f ? "red": "black";
    fig2.attributes["stroke"].value = f ? "black" : "red";
  }, 1000);
};


Всё прекрасно работает в двух браузерах - CHROME и OPERA, но MOZILLA снова отличился. Выкидывает ошибку: TypeError: w.svgload_html is not a function ссылаясь на эту строку: w.svgload_html(evt); и стопорит дальнейшее исполнение скрипта:

0d2b4e1e70ac42f093374ba207f4238a.PNG

Друзья, как обойти эту проблему? Спасибо...

P.S. Попробовал объявить раньше, но ничего не изменилось и вот почему.
Решил в отладчиках браузеров сравнить вывод svg-файла, в котором и объявляется функция w.svgload_html(evt);
и оказалось, что Mozilla попросту не отображает, вырезает содержимое Поэтому и ругается на функцию, потому что попросту её нет. Как тут побороть? Посоветуйте...

d1811d6fa7e248788935b4d5b8dec08d.png
  • Вопрос задан
  • 135 просмотров
Подписаться Оценить Комментировать
Решения вопроса 1
@z0ddak Автор вопроса
Мордор напоминает о себе
Решил так - просто сгенерировал элемент:
<!-- вставляем элемент object в div -->
<div id="monitor_svg" class="uk-text-center"></div>

// Генерируем и вставляем элемент
var object = document.createElement('object');
document.getElementById('monitor_svg').appendChild(object);

object.setAttribute( 'type', 'image/svg+xml' );
object.setAttribute( 'width', '420' );
object.setAttribute( 'height', 'auto' );
object.setAttribute( 'data', '//.../file.svg' );

// Объявляем функцию
window.svgload_html = function(evt) {
  var svg = evt.target, //Вот он, корневой узел DOM SVG
      f = false, fig1 = svg.getElementById("fig1"), fig2 = svg.getElementById("fig2");
  setInterval(function() {
    f = !f;
    fig1.attributes["fill"].value = f ? "black" : "red";
    fig1.attributes["stroke"].value = f ? "red" : "black";
    fig2.attributes["fill"].value = f ? "red": "black";
    fig2.attributes["stroke"].value = f ? "black" : "red";
  }, 1000);
};
Ответ написан
Комментировать
Пригласить эксперта
Ваш ответ на вопрос

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

Похожие вопросы
23 янв. 2025, в 19:29
700 руб./в час
23 янв. 2025, в 19:29
17000 руб./за проект
23 янв. 2025, в 19:11
2500 руб./за проект