SVG внутри ‹div› всегда больше контейнера

У меня есть огромный файл SVG внутри DIV. Я хотел бы прокрутить SVG внутри div, щелкнув ссылку A.

Моя проблема в том, что я хотел бы, чтобы мой DIV оставался меньше, чем мой документ SVG, поэтому у меня могут быть активные полосы прокрутки. Допустим, высота моего SVG-документа составляет 10 000 и ширина 1 100 внутри элемента DIV размером 200 x 100 пикселей. Но что бы я ни делал, мой элемент DIV становится таким же большим, как SVG. Как я могу ограничить размер моего div?

Вот мой код:

<html>
<title>
YOP
</title>

<head>

<style TYPE="text/css"> 
<!--
  div.header{

background:black;
background-color: #ededed; 
margin-top: 0px;
position: fixed;
top: 0px;
//width:100%;
width:1100px;
height: 500px;
   }

 -->
 </style>


<script type="text/javascript" >        
      var pos = 0;

       function  MyFtion(){
       var elem = document.getElementById('aSVG');      

       pos = pos + 100;
       elem.scrollTop = pos + 100;
       window.scroll(0,   pos);

      }
 </script>
 </head>

 <body bgcolor="white" >

        <div class="header" id="MyDiv2">
        <a href='javascript:MyFtion()'>** Move s**</a> 
        </div>


    <div id="oo"  height="200px" width="100px" style="margin-top:100px;overflow:scroll;" >          
            <object id="aSVG" data="out.svg"  style="margin-top:100px;overflow:hidden;" /> 
    </div>


  </body>
 </html>

Обратите внимание, что я пытался добавить display:block; в стиль моего тега OBJECT, но это не сработало.

Спасибо за помощь,

Антуан


person pasta    schedule 25.05.2011    source источник


Ответы (2)


Иногда HTML-атрибуты height и width плохо работают с CSS, поэтому попробуйте использовать эквиваленты CSS.

#oo{
  height:200px;
  width:100px;
  margin-top:100px;
  overflow:scroll;
}
person nkorth    schedule 25.05.2011
comment
Большое спасибо, нкорт. Оно работает !!!!!!!! Это действительно странно, что наоборот не работает, я чуть не сошел с ума... - person pasta; 25.05.2011
comment
Спасибо. Я забыл о переполнении: прокрутите - person kolobok; 06.06.2016
comment
Я не нашел решение. в чем тут разница? - person Abhi; 15.03.2017
comment
Я прибыл сюда, имея дело со странным дополнением, появляющимся за пределами моего SVG. Конкретно настройка ч/б исправит. - person ow3n; 01.05.2020

Определите ширину и высоту в svg:

<svg version="1.1" id="baum" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" x="0px" y="0px"
     width="100%"
     xml:space="preserve">

во что-то вроде этого:

<svg version="1.1" id="baum" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" x="0px" y="0px"
width="1000px" height="1000px" viewBox="0 0 200 200"
     xml:space="preserve">

Я еще не пробовал.

person user2232350    schedule 01.04.2013