Eingerostet: Pre passt sich nicht Inhalt an

Eingerostet ist mein CSS-Wissen:

--- snip ---

  
<?xml version='1.0' encoding='utf-8' ?>  
<!DOCTYPE html PUBLIC '-//W3C//DTD XHTML 1.0 Strict//EN' 'http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd'>  
  
<html lang='de' xmlns='http://www.w3.org/1999/xhtml' xml:lang='de'>  
  <head>  
    <meta content='text/html; charset=utf-8' http-equiv='Content-Type'/>  
    <title>Beispiel</title>  
    <style type='text/css'>pre {background:azure; border:thin solid red; padding:1em;}</style>  
  </head>  
  
  <body>  
    <pre>Lorem ipsum dolor sit amet, consectetuer adipiscing elit. Aenean commodo ligula eget dolor. Aenean massa. Cum sociis natoque penatibus et magnis dis parturient montes, nascetur ridiculus mus. Donec quam felis, ultricies nec, pellentesque eu, pretium quis, sem. Nulla consequat massa quis enim. Donec pede justo, fringilla vel, aliquet nec, vulputate eget, arcu. In enim justo, rhoncus ut, imperdiet a, venenatis vitae, justo. Nullam dictum felis eu pede mollis pretium. Integer tincidunt. Cras dapibus. Vivamus elementum semper nisi. Aenean vulputate eleifend tellus.</pre>  
  </body>  
</html>  

--- snip ---

das ist einfach eine laaange Zeile Text.

ich möchte, daß das pre-element sich dem Inhalt anpasst, aber im Firefox (3.6.21) geht es nur so weit wie das Anzeigefenster, der Rest des Textes fliesst drüber. Wie geht das noch mal?

Gruß, der Eingerostete

  1. Hallo Eingerostet,

    ich möchte, daß das pre-element sich dem Inhalt anpasst, aber im Firefox (3.6.21) geht es nur so weit wie das Anzeigefenster, der Rest des Textes fliesst drüber. Wie geht das noch mal?

    white-space: pre-wrap;

    Grüße,
    Thomas

    1. hallo Thomas,

      white-space: pre-wrap;

      Danke, aber nicht der Inhalt soll dem dem pre, sondern das pre dem Inhalt angepasst werden. Der Inhalt soll nicht umgebrochen werden. wenn diese Textzeile also 500em lang ist, soll das pre auch so lang sein und der body bietet dann Scrollbalken an.

      Gruß, der Eingerostete

      1. Hallo Eingerostet,

        Danke, aber nicht der Inhalt soll dem dem pre, sondern das pre dem Inhalt angepasst werden.

        overflow: auto;

        Grüße,
        Thomas

        1. Hallo ThomasM,

          overflow: auto;

          Dann hat das pre Scrollbars und ist weiterhin so breit wie das Anzeigefenster.
          overflow:visible ist eigentlich am besten, Text ist sichtbar und body (html?) hat scrollbars. Nur der Hintergrund und der Rahmen des pres machen eben nicht mit.

          Gruß

          1. Moin,

            http://misterunknown.de/test/testing.htm

            body { overflow:auto; }  
            pre { position:absolute; }
            

            Grüße Marco

            1. Hallo,

              Auch wenn Dir jemand ohne jegliche fachliche Kompetenz ein "fachlich hilfreich" gab - absolute Positionierung von Elementen ist oft unbrauchbar. Ausnahme Elemente, die oben links bleiben, wie Logo oder Menü. da kann ich dann den anderen Elementen ein margin-left/margin-top verpassen. Dieses Pre soll jedoch im Fließtext erscheinen, was ich allerdings nicht erwähnt habe. Wenn ich hier ein zweites Pre hinzufüge, funktioniert die Lösung nicht mehr.

              Gruß, ypselon (ehemals der Eingerostete)

              1. @@ypselon:

                nuqneH

                Dieses Pre soll jedoch im Fließtext erscheinen, was ich allerdings nicht erwähnt habe. Wenn ich hier ein zweites Pre hinzufüge, funktioniert die Lösung nicht mehr.

                Doch. Da das pre-Element einzeilig ist, kennst du dessen Höhe und kannst das nachfolgende Element pre+* auf Abstand halten. Meine bevorzugte Lösung wäre das allerdings auch nicht.

                Gruß, ypselon (ehemals der Eingerostete)

                Warum wechselst du mitten im Thread deinen Namen?

                Qapla'

                --
                Gut sein ist edel. Andere lehren, gut zu sein, ist noch edler. Und einfacher.
                (Mark Twain)
              2. Om nah hoo pez nyeetz, ypselon!

                absolute Positionierung von Elementen ist oft unbrauchbar.

                Im Beispiel ist das pre-Element deshalb auch gefloatet.

                Matthias

                --
                1/z ist kein Blatt Papier.

                1. Moin,

                  Im Beispiel ist das pre-Element deshalb auch gefloatet.

                  Ich hatte es wirklich absolut positioniert :)
                  Habs nur gerade geändert und mit Float probiert.

                  Grüße Marco

              3. Moin,

                Dieses Pre soll jedoch im Fließtext erscheinen, was ich allerdings nicht erwähnt habe. Wenn ich hier ein zweites Pre hinzufüge, funktioniert die Lösung nicht mehr.

                Mit Float funktioniert es auch (guckst du).
                Allerdings verstehe ich nicht, warum man im Fließtext bewusst ein horizontales Scrollen erwirken will. Bei pixelgenauen Layouts nimmt man das eben in Kauf, wenn der Viewport kleiner ist, aber sonst...

                Grüße Marco

  2. Wir haben gelöst.

    mit float und clear (und dem Elternelement gegebenfalls ein overflow:auto verpassen) hat es geklappt. Hat irgend etwas damit zu tun

    Gruß, der nicht mehr ganz so Eingerostete