Kategorien
Browser

Der neue UA-String des Internet Explorer 12 / Spartan / Windows 10

Schmeißt euer Browser-Sniffing weg – wenn ihr das nicht eh schon getan habt –, der nächste Internet Explorer kommt mit folgendem User-Agent:

Mozilla/5.0 (Windows NT 6.4; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/36.0.1985.143 Safari/537.36 Edge/12.0

Was sonst noch neu an der nächsten Version ist, steht im IE Blog von Microsoft: https://web.archive.org/web/20151122014937/http://blogs.msdn.com/b/ie/archive/2014/11/11/living-on-the-edge-our-next-step-in-interoperability.aspx

Kategorien
Frontend: HTML5, CSS3, jQuery

Verschachtelung von @media / Media Queries

Update, Februar 2016: Ab Safari 6.1 (OS X) wurde das Verhalten verändert und auch hier wird nun die zweite content-Deklaration („at media in at media“) angezeigt. IE11 hat noch das gleiche Verhalten wie IE9 und IE10 inne und zeigt nur das erste content. Microsofts Edge widerum macht es nach CSS3 und stellt das zweite content dar.

Vor ein paar Wochen stolperte ich über die verschiedenen Interpretationen von verschachtelten @media-Anweisungen. Die jeweils aktuellen Versionen von Safari auf OS X (6.0.3) und iOS (6.0) sowie IE9 und IE10 interpretierten den nachfolgenden Code etwas anders als Firefox (20.0) und Chrome (26.0.1410.65):

@media screen {
  .wrapper {
    dispay: block;
  }
  .wrapper:before {
    content:"at media";
    display: block;
  }
  @media screen and (min-width: 2em) {
    .wrapper:before {
      content:"at media screen in at media";
    }
  }
}
Check out this Pen!

Die Safaris nämlich schreiben den ersten content („at media“) auf die Seite, Firefox und Chrome den zweiten („at media screen in at media“). Beim Internet Explorer sieht es so aus: IE9 und IE10 zeigen den ersten content. Mich interessierte wieso das so ist und was richtig ist: die Safaris verhalten sich nach dem CSS-2.1-Regelwerk, das kein verschachteln von @media-Regeln erlaubt:

At-rules inside @media are invalid in CSS2.1.

Die CSS-3-Spezifikation hingegen, wonach sich Firefox und Chrome richten, erlaubt es.

This means that when multiple conditional group rules are nested, a rule inside of both of them applies only when all of the rules‘ conditions are true.

Detaillierter erklärt hat es Daniel Tan bei Stack Overflow:

Now, the actual issue here is that nested @media rules are not valid in CSS2.1 because you’re not allowed to nest any at-rules within @media rules. However, things seem quite different in CSS3. Namely, the CSS3 Conditional Rules module states very clearly that @media rules can be nested, even providing an example:

Natürlich kann man sich fragen, wieso man die beiden @media-Regeln überhaupt verschachtelt. Das kam daher, dass ich mit der Contao-Erweiterung theme_plus ein Stylesheet einband und diesem eine @media-Anweisung auf den Weg gab. Dazu dann noch das Media Query im Stylesheet selbst und schon stolperte ich über das oben genannte Problem.

Einen wirklichen Rat kann ich euch nicht auf den Weg geben. Achtet darauf, ob und welche @media-Anweisungen ihr verschachtelt. Ich habe zum Beispiel die für das gesamte Dokument entfernt, da ich sie im Stylesheet nicht benötigte – und auch im ersten Moment nicht mitbekam, dass sie mitgegeben wird. Wenn ihr eure Stylesheets nur für eine Geräteklasse verwenden lassen wollt, könnt ihr dies auch im <link /> angeben: <link media="screen" />. Oder ihr schreibt eure Media Queries, wenn sie in einem @media-Screen-Selektor stehen nur folgendermaßen: (max-width: 40em) { color: #b4d455; }

Kategorien
Browser

Virtuelle Maschinen für IE6, IE7, IE8, IE9, IE10, IE11/Edge direkt von Microsoft

Microsoft ist abermals in Spenderlaune und bietet uns geplagten Webentwicklern alle Internet-Explorer-Versionen von 6-10 6-11/edge in kostenlosen Virtual Machines an.

Kategorien
Webdesign/Gestaltung

Sehr kluge Worte über die geplanten Autoupdates des Internet Explorer

Gerrit van Aaken hat sich die Sache mit den automatischen Updates des Internet Explorer, die Microsoft plant und angekündigt hat, mal angesehen und kommt zum Schluss:

Microsoft hat von daher vor allem eine Weichenstellung für die Zukunft getroffen. Es betrifft in erster Linie WinVista und Win7-Nutzer, die jetzt mit noch größerer Wahrscheinlichkeit etwas schneller die aktuellen IE-Versionen nutzen werden. Das ist unbedingt zu begrüßen!

Ich behaupte aber, dass unter Windows XP alles beim alten bliebt, und die bisherige Sterbegeschwindigkeit von IE6 und IE7 exakt gleich bleibt.

Mehr in seinem Blog: Die große Internet-Explorer-Autoupdate-Übertreibung. Auch wenn ihr euch schon gefreut habt, den IE6 und IE7 endlich los zu sein: ein schönes Wochenende!