Как внедрить SVG с использованием SVGweb, когда загружен jQuery (т.е. проблема) - PullRequest
2 голосов
/ 07 ноября 2011

Это svg, который я пытаюсь вставить:

  <script type="image/svg+xml">
    <svg width="200" height="200"
         style="background-color: #D2B48C; display: block; margin-bottom: 5px;"
         id="embeddedSVG">
      <g id="myGroup" 
         fill="blue" 
         style="font-size: 18px; text-anchor: middle; font-family: serif;">
        <circle id="myCircle"
                cx="100" cy="75" r="50"
                stroke="firebrick"
                stroke-width="3" />
        <text x="100" y="155">Hello World</text>
        <text x="100" y="175">From Embedded SVG!</text>
      </g>
    </svg>
  </script>
  <noscript>
    <h1>Optional fallback content goes here!</h1>
  </noscript>

Это нормально работает в ie6-8, SVGweb делает:

<OBJECT style="BACKGROUND-COLOR: #d2b48c; DISPLAY: block; MARGIN-BOTTOM: 5px; OVERFLOW: hidden" id=embeddedSVG_flash class=embedssvg name=embeddedSVG_flash codeBase="http://fpdownload.macromedia.com/pub/shockwave/cabs/flash/swflash.cab#version=10,0,0,0" classid=clsid:d27cdb6e-ae6d-11cf-96b8-444553540000 width=200 height=200><PARAM NAME="_cx" VALUE="5291"><PARAM NAME="_cy" VALUE="5291"><PARAM NAME="FlashVars" VALUE=""><PARAM NAME="Movie" VALUE="js/svg.swf"><PARAM NAME="Src" VALUE="js/svg.swf"><PARAM NAME="WMode" VALUE="Window"><PARAM NAME="Play" VALUE="0"><PARAM NAME="Loop" VALUE="-1"><PARAM NAME="Quality" VALUE="High"><PARAM NAME="SAlign" VALUE="LT"><PARAM NAME="Menu" VALUE="-1"><PARAM NAME="Base" VALUE=""><PARAM NAME="AllowScriptAccess" VALUE="always"><PARAM NAME="Scale" VALUE="NoScale"><PARAM NAME="DeviceFont" VALUE="0"><PARAM NAME="EmbedMovie" VALUE="0"><PARAM NAME="BGColor" VALUE="D2B48C"><PARAM NAME="SWRemote" VALUE=""><PARAM NAME="MovieData" VALUE=""><PARAM NAME="SeamlessTabbing" VALUE="1"><PARAM NAME="Profile" VALUE="0"><PARAM NAME="ProfileAddress" VALUE=""><PARAM NAME="ProfilePort" VALUE="0"><PARAM NAME="AllowNetworking" VALUE="all"><PARAM NAME="AllowFullScreen" VALUE="false">
      <embed src="js/svg.swf" quality="high" bgcolor="#d2b48c" 
width="200" height="200" id="embeddedSVG_flash" name="embeddedSVG_flash" swLiveConnect="true" allowScriptAccess="always" type="application/x-shockwave-flash" FlashVars="uniqueId=embeddedSVG&sourceType=string&clipMode=both&debug=true&svgId=embeddedSVG" pluginspage="http://www.macromedia.com/go/getflashplayer" style="background-color: #d2b48c; display: block; margin-bottom: 5px;overflow: hidden;"
 class="embedssvg"  /></OBJECT><NOSCRIPT></NOSCRIPT>

но когда я добавляю jQuery:

<script src="js/jquery.js" type="text/javascript"></script>

SVG не выполняет рендеринг в ie6-8 (но в chrome, ff, ...):

<script type="image/svg+xml">
<svg width="200" height="200" style="background-color: #D2B48C; display: block; margin-bottom: 5px;"              id="embeddedSVG">           
<g id="myGroup" fill="blue" style="font-size: 18px; text-anchor: middle; font-family: serif;">                <circle id="myCircle"  cx="100" cy="75" r="50" stroke="firebrick" stroke-width="3" />           
<text x="100" y="155">Hello World</text>             
<text x="100" y="175">From Embedded SVG!</text>           
</g>         
</svg>
</script>

Я бы ожидал, что SVGweb будет работать одинаково, независимо от того, загружен ли jQuery или нет. Как мне встроить SVG в SVGweb, чтобы он отображался в ie6-8 при загрузке jQuery?

EDIT:

Возможно, я нашел решение. Если я приведу jQuery до SVGweb, он будет работать. Тем не менее в руководстве SVGweb говорится:

Во-первых, вы должны добавить файл svg.js на свою HTML-страницу как первый скрипт на вашей странице, прежде чем все остальные

Ответы [ 2 ]

0 голосов
/ 18 июля 2012

Ваше решение не подходит, потому что svgWeb, вероятно, переопределит функции jQuery, такие как обработчики событий onload ... Попробуйте обновить svgWeb до последней версии и поместить его обратно в качестве первого тега сценария в вашем головном узле.

@ Mathias

Вы пробовали этот синтаксис? У меня это сработало.

mysvg.load = mysvg.onsvgload = function(){
    //Handler
}
0 голосов
/ 14 января 2012

Включая jQuery до того, как SVGweb решит проблему (как указано в моем редактировании).

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...