Internet Explorer 11 ignoriert list-style:none beim ersten Laden

Lesezeit: 5 Minuten

Benutzer-Avatar
David Apltauer

Ich verwende das Superfish jQuery-Plugin für mein Menü. In Chrome und im mobilen Opera-Emulator funktioniert es gut, aber in Internet Explorer 11 die CSS-Eigenschaft list-style:none gilt nur für die oberste Ebene des Menüs und nicht für die umgeschalteten Untermenüs, obwohl es in der Ansicht der Entwicklungswerkzeuge anscheinend für die entsprechenden Elemente gilt. Daraus ergibt sich: Fehlerhaftes Menü
Die verwendeten dieses CSS:

/*** ESSENTIAL STYLES ***/
.sf-menu, .sf-menu * {
    margin: 0;
    padding: 0;
    list-style: none;
}
.sf-menu li {
    position: relative;
}
.sf-menu ul {
    position: absolute;
    display: none;
    top: 100%;
    left: 0;
    z-index: 99;
}
.sf-menu > li {
    float: left;
}
.sf-menu li:hover > ul,
.sf-menu li.sfHover > ul {
    display: block;
}

.sf-menu a {
    display: block;
    position: relative;
}
.sf-menu ul ul {
    top: 0;
    left: 100%;
}


/*** DEMO SKIN ***/
.sf-menu {
    float: left;
    margin-bottom: 1em;
}
.sf-menu ul {
    box-shadow: 2px 2px 6px rgba(0,0,0,.2);
    min-width: 12em; /* allow long menu items to determine submenu width */
    *width: 12em; /* no auto sub width for IE7, see white-space comment below */
}
.sf-menu a {
    border-left: 1px solid #fff;
    border-top: 1px solid #dFeEFF; /* fallback colour must use full shorthand */
    border-top: 1px solid rgba(255,255,255,.5);
    padding: .75em 1em;
    text-decoration: none;
    zoom: 1; /* IE7 */
}
.sf-menu a {
    color: #13a;
}
.sf-menu li {
    background: #BDD2FF;
    white-space: nowrap; /* no need for Supersubs plugin */
    *white-space: normal; /* ...unless you support IE7 (let it wrap) */
    -webkit-transition: background .2s;
    transition: background .2s;
}
.sf-menu ul li {
    background: #AABDE6;
}
.sf-menu ul ul li {
    background: #9AAEDB;
}
.sf-menu li:hover,
.sf-menu li.sfHover {
    background: #CFDEFF;
    /* only transition out, not in */
    -webkit-transition: none;
    transition: none;
}

/*** arrows (for all except IE7) **/
.sf-arrows .sf-with-ul {
    padding-right: 2.5em;
    *padding-right: 1em; /* no CSS arrows for IE7 (lack pseudo-elements) */
}
/* styling for both css and generated arrows */
.sf-arrows .sf-with-ul:after {
    content: '';
    position: absolute;
    top: 50%;
    right: 1em;
    margin-top: -3px;
    height: 0;
    width: 0;
    /* order of following 3 rules important for fallbacks to work */
    border: 5px solid transparent;
    border-top-color: #dFeEFF; /* edit this to suit design (no rgba in IE8) */
    border-top-color: rgba(255,255,255,.5);
}
.sf-arrows > li > .sf-with-ul:focus:after,
.sf-arrows > li:hover > .sf-with-ul:after,
.sf-arrows > .sfHover > .sf-with-ul:after {
    border-top-color: white; /* IE8 fallback colour */
}
/* styling for right-facing arrows */
.sf-arrows ul .sf-with-ul:after {
    margin-top: -5px;
    margin-right: -3px;
    border-color: transparent;
    border-left-color: #dFeEFF; /* edit this to suit design (no rgba in IE8) */
    border-left-color: rgba(255,255,255,.5);
}
.sf-arrows ul li > .sf-with-ul:focus:after,
.sf-arrows ul li:hover > .sf-with-ul:after,
.sf-arrows ul .sfHover > .sf-with-ul:after {
    border-left-color: white;
}

(Das Menü ul hat die Klasse sf-menu). Noch interessanter ist, dass beim zweiten oder weiteren Besuch derselben Seite diese korrekt angezeigt wird. Beim ersten Laden der IE-Instanz wird es jedoch immer falsch angezeigt.

BEARBEITEN: Wenn ich stattdessen die Listenstilregel für jede ul setze, funktioniert es wie erwartet.

  • Welp, 10 war nett … Willkommen zurück zum normalen IE … fragt sich, ob dies bedeutet, dass FF endlich sein CSS-Absturz-JS-Problem beheben und wieder ein nützlicher Browser sein wird …

    – SpYk3HH

    3. Dezember 2013 um 16:25 Uhr

  • Können Sie Fiddle posten, um das Problem zu reproduzieren? Weil es hier nicht passiert: jsfiddle.net/tyqSm/1

    – Juri Galanter

    4. Dezember 2013 um 1:51 Uhr


Antwort an Peter:

Keine Ahnung ob das besser wäre. Kopiert von der jquery git

list-style-image: url();

  • Das ist die beste Antwort! Vielen Dank!

    – Alon Schmiel

    8. August 2015 um 12:42 Uhr

  • Groß! Funktioniert bei mir. Danke, dass du zu jquery git gebohrt und das herausgefunden hast, großartig 🙂

    – Anmol Saraf

    13. Juli 2016 um 16:18 Uhr

  • Wenden Sie dies auf das

      oder das

    • an?

      – Stackingjasoncooper

      19. Juli 2016 um 14:35 Uhr

  • @stackingjasoncooper Ich habe das auf

    1. angewendet und es hat wie ein Zauber funktioniert.

      – Markus Lohr

      17. August 2016 um 19:32 Uhr

  • Das funktioniert für mich. Die Antwort unten – url(data:0) – nicht. Für diejenigen, die sich fragen, erstellt der obige Code den kleinsten Daten-URI für ein transparentes Bild. (über stackoverflow.com/questions/6018611/…)

    – David Yeiser

    9. Mai 2019 um 16:19 Uhr

Ich hatte ein ähnliches Problem in IE11 und das Festlegen des Listenstils für die ul hat es nicht gelöst. Aber ich habe folgende Lösung gefunden hier was für IE11 funktioniert hat:

.sf-arrows li {
    list-style-image: url(data:0);
}

  • Dies gibt einen 404-Fehler in Chrome und verbraucht 200 ms Ladezeit. Bitte lesen Sie die Antwort von Dummy unten, um diesen Ansatz besser zu verstehen.

    – Andrew Craswell

    5. August 2015 um 1:20 Uhr

  • Oder packen Sie es einfach in eine IE/Edge-Medienabfrage?

    – brandito

    10. Dezember 2017 um 22:57 Uhr

  • Dies war die einzige Lösung, die für mich zu funktionieren schien.

    – brandito

    10. Dezember 2017 um 23:16 Uhr

Dokumentiert hier

Hatte das gleiche Problem. Es ist ein Fehler in zB 10 und 11. list-style: none wird nicht angewendet, wenn die Liste auch Stile hat display: none in einem externen Stylesheet. Es funktioniert, wenn Sie display none inline auf das Element anwenden und es aus dem externen CSS entfernen.

<ul style="display: none;"></ul>

  • Dies sollte als Lösung markiert werden. Funktioniert perfekt.

    – Randy Cleary

    8. Juli 2014 um 13:41 Uhr

Benutzer-Avatar
Anna Keren

Ich hatte genau das gleiche Problem im IE 11.

Hinzufügen eines Inline-Stils zur <ul> Element hat bei mir funktioniert:

<ul style="list-style: none;">

Einstellung list-style: none in einer externen CSS-Datei schien nicht zu funktionieren.

Fügen Sie den Stil dem UL hinzu

.flexnav ul {
    list-style: none;
    list-style-image: none;
    list-style-type: none;
}

  • Dies hätte die gewählte Antwort sein sollen, da es sich um die tatsächlichen Stile im IE handelt, die angesprochen werden müssen, und nicht um die anderen hier veröffentlichten Problemumgehungen.

    – Modular

    23. April 2018 um 16:45 Uhr

  • Ich stimme @bit-less zu 100% zu, wobei dies der Fall ist Korrekt (und immer noch relevant) Antworten. Das explizite Festlegen jeder Eigenschaft löste Bootstrap 3.3.7 auf .dropdown-menu Probleme, die ich in Microsoft Edge 42.17134.1.0 hatte.

    – Mavelo

    2. September 2018 um 16:51 Uhr


Benutzer-Avatar
Roman ni

Das Positionieren der Kugel außerhalb und das Anwenden eines versteckten Überlaufs auf dem Li hat es für mich getan. Es ist noch da, aber nicht zu sehen. So:

li {
list-style-position: outside;
overflow: hidden;
}

  • Dies hätte die gewählte Antwort sein sollen, da es sich um die tatsächlichen Stile im IE handelt, die angesprochen werden müssen, und nicht um die anderen hier veröffentlichten Problemumgehungen.

    – Modular

    23. April 2018 um 16:45 Uhr

  • Ich stimme @bit-less zu 100% zu, wobei dies der Fall ist Korrekt (und immer noch relevant) Antworten. Das explizite Festlegen jeder Eigenschaft löste Bootstrap 3.3.7 auf .dropdown-menu Probleme, die ich in Microsoft Edge 42.17134.1.0 hatte.

    – Mavelo

    2. September 2018 um 16:51 Uhr


Benutzer-Avatar
Benutzer1122002

Diese Lösung funktioniert perfekt für mich, die einzige, die funktioniert hat

.sf-arrows li {
list-style-image: url(data:0);
}

Danke, dass du es geteilt hast

1176180cookie-checkInternet Explorer 11 ignoriert list-style:none beim ersten Laden

This website is using cookies to improve the user-friendliness. You agree by using the website further.

Privacy policy