IE8 May Not Pass the Acid2 Test After All
dotne writes "CNET has published an article called Acid2, Acid3 and the power of default. The article predicts that IE8 will not pass the Acid2 test after all: '[Another] scenario could be that Microsoft requires Web pages to change the default settings by flagging that they really, really want to be rendered correctly. Web pages already have a way to say this (called doctype switching, which is supported by all browsers), but Microsoft has all but announced that IE8 will support yet another scheme. If the company decides to implement the new scheme, the Acid2 test — and all the other pages that use doctype switching — will not be rendered correctly.' Microsoft's IE8 render modes have been discussed here previously, and they've caused an uproar in the web development community. According to the scheme, authors must put Microsoft-specific <meta> tags into their pages in order for them to be rendered correctly. I doubt Acid2, nor Acid3 will have Microsoft extensions in them."
> I doubt Acid2, nor Acid3 will have Microsoft extensions in them.
But lots of web pages will.
Another Microsoft "We'll do it our way, and you'll do it our way too if you know what's good for you."
I wish Microsoft would at least learn to fake sincerity in actually following common standards. This isn't even lip service. This is "We follow standards (for certain Microsoft-centric values of 'standards')."
Of course, the market has rewarded them, so why should they change? All they need is smoke, some mirrors, and some moderately-skilled PR, et Voilà! "standards-compliant!"
Welcome to the Panopticon. Used to be a prison, now it's your home.
Shove the anti-MS rhetoric in the closet for a moment and think about it.
IF MS were to change the way pages rendered with existing doctypes, millions of pages could/would render differently requiring businesses and individuals across the world to either re-vamp their websites or at least change the existing doctype to a new name that referred to the old rendering style.
Alternatively, they can create a new doctype specifically for the new "more better" rendering. This way, the millions of existing pages that are already designed to render in the exiting style will continue to do so, and anyone looking to use a closer to the standards rendering has the option to.
That ACID(2,3) tests are designed to test browsers, browsers are not designed to test ACID. As such, ACID should be updated to include the new doctype option for IE.
Okay, NOW you can pull that anti-MS rhetoric back out and ask: "WHY THE HELL DIDN'T THEY DO IT RIGHT THE FIRST TIME?!?!?"
-Rick
"Most people in the U.S. wouldn't know they live in a tyrannical state if it walked up and grabbed their junk." - MyFirs
So I actually read TFA, and it seems that this isn't just a MS thing; in fact it looks to be a standards thing that MS will just happen to be the first to support. Funny how the slashdot crowd automatically makes assumptions and jumps all over MS's case; even when they do something right.
The basic concept is preserving HTML based content for the future despite advancement in rendering software. Sounds like a good idea to me.
- I voted for Nintendo and against Bush
But I don't think that we are going to see much of that special tag anyway since those who care about standards will shy it and those who doesn't will ignore it anyway and continue with their broken pages...
But wasn't Microsoft going to push Silverlight (or whatever they call it) instead???
At least - we need this tag and the circumventions for special pages about as much as we need severe dandruff...
If builders built buildings the way programmers wrote programs, then the first woodpecker would destroy civilization.
I replied on the previous thread on this.. I shouldn't really post again, but I feel I have to.
Yes, in a magical perfect world, Microsoft would use DOCTYPE to tell if a page wants standard-compatible rendering, and simply break all the pages which have a correct DOCTYPE but then rely, either on purpose or by accident, on IE6 and IE7 bugs. But most of their customers don't want them to, and so they aren't going to.
Therefore they are trying to offer an alternative. An alternative you can either put in as a meta tag or a HTTP header. I can't think of anything they could do in practice which would be better than this, other than the one thing they would never do, which is break old webpages which rendered correctly on IE6/7.
Combination - fun iPhone puzzling
I just want to point out that these ongoing shenanigans show that IE is not a web browser. The whole world (including Microsoft) got together and decided exactly what a "web page" is and wrote it down in very clear specifications. So, anyone who writes a piece of software that renders a web page, as defined by those specifications, is a web browser. If you write software that does anything else, then that isn't a web browser. Therefore, insofar as IE does not render web pages, it is not a web browser. So, if anyone complains that your documents don't look right when they view them in IE, gently explain to them that your documents are web pages, and to view them the person needs a web browser, and IE isn't a web browser.
That leaves open the question of exactly what IE is.
Someone mod parent up.
I admit when I first heard about this in a previous article (in which it was claimed IE8 wouldn't used standards mode UNLESS the meta tag was added), I figured it was business as usual for MS, but after reading the full rational behind this, I think people have misinterpreted the intention. As long as the browser defaults to standards compliant, and only switches to a particular rendering mode in the presence of the meta tag, then this is a useful way to force a page to be rendered in a way you actually intended. This also appears to be a design originating from outside of MS, they asked other developers for suggestions of how to tackle this problem, and the meta tag solution was the one recommended to them.
Curiosity was framed, Ignorance killed the cat.
The meta tag is a GOOD idea, they just put it in the wrong place, EXISTING websites should be able to add a meta tag to continue use of the existing quirks mode, and going forward the default could then be acid mode.
With that setup if people really wanted their website to render the old way they could just add a meta tag, and it doesn't mess with the new version of ie
Yes, let the site break by default. Let it render like hell, without any change to the site. Just offer the user a "try to make this site look better" button, that will switch through the various so-called "compatibility" rendering modes.
Microsoft always does this; they ignore the user and focus on the developers (recall Ballmer's silly rant). Think about that for a moment. Their real market demand comes more indirectly from developers building software (yes, including web sites) that need Microsoft, and they know that.
But they're not blind to the users, nor do they always fear change. Think of the XP interface for folks who upgraded from 2000. It looked like a cartoon and took up lots of real estate. Users adapted; a change caused by an upgrade didn't bother them in the long run. Some [gasp] even found that Microsoft provided a nice "classic" option that restored their old look at feel. Even IE7 removed the menu bar by default, but let users restore it.
Now--stay with me for a context shift--the same can be true of a browser. The browser is a client-side piece of software. It can be upgraded, and the upgrade can make things different. Yes, even by default. But let the users click a button to have IE re-render any broken sites (site-wide, of course). Oh, what a burden, I can hear you protest. Fine, let's allow users to even set a preference that all sites should be set to use this "compatibility" mode by default. Then, if some seldom-used site looks bad because a user managed to stumble across one of the few odd standards-compliant sites (please mind the sarcasm) then they can set an exception for this site.
Basically your premise there is flawed; there's a false dichotomy you've presented to fix the breaking of millions of sites. Both of your solutions require the developers to take some action, one indeed less painful than the other.
I'm fine, Microsoft, with you inventing and respecting some non-standard tag, but let me be the voice of developers everywhere begging you to please let us summarily ignore this. Further, I suggest (yes, I'm still talking to you, Microsoft!) you not burden your prized developers any further, and actually consider distributing the pain as a much smaller burden on the end-users. They can and will adapt, soon, as long as you're sure to empower them with sufficient options to fix for themselves the mess you've made by thumbing your nose at web standards for all these years. It's Ok, admit you were wrong about web standards and do an about-face, just as you did with the Internet itself a decade ago.
Forgive me if I'm wrong (as I'm not an HTML guru in the least) but isn't that the point of DOCTYPE? Meaning, if a broken page wants to use the buggy renderer they shouldn't be setting a strict DOCTYPE.
Microsoft is so committed to their long-standing policy of coddling the incompetent that they want a way to be lax on pages that specifically request a strict interpretation.
I have seen the future, and it is inconvenient.
What's not to like? This tag allows the people that are writing horrible IE-only HTML/CSS in Visual Studio today to continue their business as usual. There is absolutely no incentive for these people to adhere to standards since the IE7 engine will be kept around for "a couple of web lifetimes" apparently (source). This effectively locks browsers other than IE out of these sites since they won't have this IE7 compatibilty.
Hooray, everybody wins. No, wait, the other one.
The issue is that IE6 allowed people to use the strict rendering with out truly strictly rendering stuff. When IE7 was released that was more strict, it broke a lot of pages that assumed that strict worked because IE6 worked.
They already corupted the doctype tag. The logic behind the new tag is to indicate the renderer you want so future releases do not break the current page.
They dont want to break the web again (like IE7 did). So the web will work by default (as defined by IE 6) and new stuff that targets the new browser should not break when IE 9 is released.
They are attempting to end a cycle of new browsers breaking older pages.
What they need to do is do it right the first time and fix rendering bugs quickly. force people to fallow the standard and it will work. Microsoft should be the most accurate implementers of the specs because they have such a huge install base.
Im a gamer, not a grammer major. This post is full of spelling and grammer mistakes.
The possible downside is that precisely because these buggy pages work in IE, noone will bother to fix them. Imagine you're at IE12 and it's now a super anal 99.9% standards compatible browser in IE12 mode. What good will it do if pages still call for IE7 compatibility mode and are still broken on every other browser? That said, between "We won't fix the browser because it'd break sites" and "We won't fix the pages because they work" I think the latter is easier to fix and new code would presumably be written to spec and work in all browsers. So it's something of a percieved downside which I don't think is real.
Now, if I take on my hat as an IE user it's a slam dunk. More pages will work. If I take on the hat as a web developer, I know my pages won't suddenly break (because you were forced to use an IE hack to make it work right in the first place). Also a slam dunk. If I take on the hat of Microsoft, they don't get screaming customers about how they broke the intranet. Also a slam dunk. If Microsoft was really really nice, they'd put in their status line "This web page is designed for a higher version of IE. Please upgrade to ensure optimum performance" too, so we'd lose these buggy versions as quickly as possible.
It's easier to cut the developers loose and let them fix IE than the pains of trying to slowly break IE while not getting killed by angry customers. The sooner they get a standards compliant browser out there, the sooner we can get to *really* fixing the problem.
Live today, because you never know what tomorrow brings
The real problem isn't on the browser side. It's in Dreamweaver, the most popular web page design tool. Dreamweaver does not create valid HTML or XHTML. Not even close. Create a page in Dreamweaver for anything later than HTML 3.2 and run it through the W3C validator. It will fail.
The basic problem is that the Dreamweaver people never really figured out what to do about CSS. In theory, CSS is supposed to have some abstract model of the format of some block of text, like TeX does. In practice, there's usually a big block of CSS with machine-generated names at the beginning of the web page. There's a fundamental disconnect between the CSS model and the Dreamweaver "Properties" box. So Dreamweaver is still inserting I, B and FONT tags.
In layout, Dreamweaver does table-based layout quite well, but DIV/FLOAT/CLEAR layout isn't handled well. Much of this is due to the limitations of the DIV/FLOAT/CLEAR approach. Tables are a 2D grid system, and map well to the drag-the-lines editor in Dreamweaver. DIV/FLOAT/CLEAR doesn't map well to a visual layout editor.
The end result is a mess. And HTML 5 doesn't help.
Secondly, it encourages the web to come to a halt, technology wise. As an expensive consultant to big companies, my experience has been that they all want to try to tell you "our web site has to look perfect on every version of every browser ever invented, period." Of course that's impossible, so once I drill it through their head that it's impossible, they have to settle for some major subset, at which time they always want me to use ancient UI technology for maximum compatibility. (Seriously, I deal with people who freak out if I want to use CSS positioning or an iframe, and god help me if I mention AJAX.) If they got the idea that browsers have a magical compatibility mode so that all future browsers will support pages written for today's browsers, they'll instantly write up a corporate policy that basically says that nothing will ever change again and for the rest of time their web site will be maintained as if it is forever 2005, and then they won't change it until someone practically holds a gun to their head to force them to.
Now, you're asking yourself, why should you care? Because it's more than a few idiots, it's a substantial portion of the web. Sure, there will always be little guys who will come along and innovate, but do you really want to deal with a web full of sites that forever use 2005 technology and just a few sites that have caught on to the latest stuff?
Businesses can do as they please, but consumers can always vote with their browsers.
Opera, Mozilla/Firefox don't have this problem so why should Microsoft. By adding a tag that specifies the browser it makes the page browser specific and since we are talking IE it is now OS specific .
Sure a web developer could code other browsers in the tag but it will be ignored by other browsers because other browsers already follow standards and don't require the hint. The metatag might as well be called "IEVersion(tm)" because that's what it is. Once again, Microsoft is trying to make a standard Microsoft specific because they are too stupid, lazy or ignorant to implement what everyone else on the planet has agreed to.
Microsoft has no intention of ever being the "most accurate implementors of the specs" because they have no incentive. Implementing a standard does not make Microsoft more money, tying people to Microsoft products does.
The tag gives Microsoft a get out of jail free card so they don't have to follow standards ever again. Using the tag only reinforces their behaviour.
Some of what I say is fact, some is conjecture, the rest I'm just blowing out my ass...you guess.
Collector's Edition
The problem is that currently you can't, and Microsoft only prolongs this situation. None of the existing pages will see the improvements. They've made it easier to keep pages broken than to fix them. Microsoft has decided that the current buggy engine should be the default, forever. You may end up maintaining hacks on pages written for IE7-bugmode long after IE7 fades into insignificance.
by refusing to accommodate a non-standards compliant browser.
As a web-dev I'm getting near the point of making webpages that look great in Firefox and other standards compliant browsers and only ensuring that the basic functionality works in IE. If things look like my dog's breakfast in IE, placing a handy link to www.getfirefox.com at the bottom of the page for viewers who want to view the site properly. Perhaps being even more vicious by writing javascript to blank out the entire page if the user is using IE.
The problem with going ahead with this Plan of Action is that it's then, me, the developer who looks like crap. It seems web developers are stuck between a rock and a hard place.
a) Don't support IE and have your pages render improperly for a fair whack of your user base, which makes you look like a bad designer or...
b) Spend countless hours fixing, tweaking, and using the myriad of IE hacks to make pages look half decent.
Usually I don't have a problem with Microsoft - hey, if they make a craptastic OS: I don't have to buy it. But when it comes to being a web developer they cause me serious headaches! I think the web development community should be up in arms about IE8.
Most consumers don't know they even have a choice.
New standards don't mean anything if no one uses them. A non-developer switching to a browser like Firefox simply because it "supports standards" would be like buying a high definition television fifteen years ago; you're still getting the same quality broadcasts.
W3 standards don't catch on because they're not intended for the end-user, they're intended for developers. End-users don't care that the columns on your website were coded in CSS rather than a table. If you want people to switch to a more developer friendly browser, you have to give 'em the old razzle dazzle. For example, let's say Macromedia Flash was introduced later in the game, relied on a W3C standard instead of a browser plugin, and that standard was only supported by non-IE browsers. Developers would be so anxious to use Flash that they would leave IE users in the dust, encouraging them to switch if they wanted to see the fancy dynamic content. IE users would then feel left out and switch to Firefox, which would end up with a 70% market share before Microsoft could even blink.
So _you_ wrote non-standards compliant pages. Now _you_ can go back and change them. That's right, you bent over backwards supporting Microsoft's broken habits, now you can pay the piper. I stopped coding for IE around late 2006 and you know what? I do not need to recode anything that I've done since then.
If users insist on using a broken browser then I let them see a broken webpage. Let them know the headaches that MS has done to those who design the web. Better yet, let those who choose to use their products (and those who choose to support their products, like you) suffer the headaches now.
I'm full aware of the fact that some people stopped looking at my sites because IE doesn't display them nice. I suffered the loss of advertising income. And you know what? It was worth it.
It is dangerous to be right when the government is wrong.
Only in a very roundabout way. The actual point of the doctype isn't anything to do with rendering engines - it is how you specify exactly which version of HTML/XHTML/(some other random XML language) etc your markup should validate against.
In terms of rendering engines, CSS doesn't (unlike HTML) have any way of defining which version you are using anyway. The different versions just kinda build on each other, and browsers are supposed to ignore anything they don't understand.
What happened was that when browser makers needed to diverge their rendering engines into quirks mode and standards compliant mode, they figured it was a reasonable assumption that any site that uses a strict doctype is going to the trouble of complying with the standards. So they used the presence of certain doctypes to switch to standards mode. And now that (pragmatic but short sighted) approach is starting to show its warts.
None of this was originally intended by the standards writers - ie people writing standards sort of assume that they are intended to be complied with. So the standards (I think HTML5 might be an exception) don't really allow for providing configurable levels of brokenness in a well thought out extensible way. Actually being able to configure how broken your code is seems a bit strange anyway.
Calling opponents of what MS is doing "academic eggheads" is extremely short sighted. The opponents of this care about the web and it's infrastructure as a whole (including browser developers) rather than just a bunch of badly hacked up user agent sniffing sites they have to maintain.
If you think user agent sniffing is the only way to do your job then I would question how you could call yourself a professional web developer.
Going down the path MS is creating by adding new rendering modes will only end in madness as every webdesigner has to specify what browser version that site is to be rendered with. When there was only quirks mode and standards mode, most people didn't see that as a problem even if the "academic eggheads" did. But will it become a problem when browsers need to support 5 different IE rendering modes, 3 different Firefox rendering modes, 2 different Opera rendering modes etc etc? Or does only MS get the privilege of writing buggy browsers that every other browser writer have to emulate?
Effectively there won't be any web standards once you get to that point - web sites will end up just be coded to one of a dozen different rendering engines. That sets back all the hard won recent progress that has been made with promoting web standards. As only MS will have the clout to make everyone follow their rendering bugs, that puts MS back in charge of browser innovation (or lack thereof) as the other browsers end up chasing their tail in an eternal Samba like reverse engineering effort. How is that good for the web as a whole? Everyone ends up with buggier bloated browsers that are harder to maintain by their developers.
All this just because some webdesigners were too lazy to figure out how to do their jobs properly, and too shortsighted to see the bigger picture of what is at stake. This isn't MS getting out of the problem they created, it is MS perpetuating it even though they have finally created a standards compliant browser. Quirks modes should be opt-in rather than opt-out, and the aim should be to eventually leave them behind rather than lock them in place forever.
Quoting another comment: MS desire to "not break the web" really means "not fix the web". Every other new IE version has done similar things before - why is it now a problem?
But even if ie8 starts in "super standard mode" a site is only giving problems with ie8 if it have a doctype, and don't work in standard browsers, such as firefox. (If firefox can render it, so can ie8 super standard mode).
And it is many years ago I saw such a buggy site. (In fact I can't think of any site where there would be problems right now.
This is the exact problem they have.
People write the page with the markup and tags they know work today. People use the retarded work arounds to make the pages look correct in IE. The problem is when the newest and greatest renderer fixes the original bug, the hack fails to work because it uses some unsupported markup/feature.
You should be able to code a page once and have it work forever. That is what microsoft is trying to get back to. This is something people want.
But this is microsofts own fault. They are trying to fix thing now but they have already corupted the standards (by not fallowing them).
Im a gamer, not a grammer major. This post is full of spelling and grammer mistakes.
"I've had hundreds more problems with FF rendering than IE rendering. That's because I start with IE, and build FF second. It's been that way for developers since the dawn of time. The primary browser is easy, the secondaries are not. You get to pick the one that you want primary."
And I am the reverse... I develop in FF first and make sure it renders there fine, then I also find that it works well in Opera and Safari 99% of the time right off the cuff... then I go back and fix poor lagging IE by working around it's rendering issues. Heck in IE7 MS ponied up and re-worked many of their known issues admitting they had been lagging behind the standards on their own blogs.
"But I'll say again what I've been saying for well over a decade. The day the W3C makes a browser that correctly meets each and every one of their standards, then I'll point to IE and others and say that they suck. Until then, it's the W3C that sucks. I too can invent standards that are difficult to follow."
So because the FAA doesn't build airplanes they shouldn't set guidelines for manufacturers? And because the FCC doesn't produce any TV programs they shouldn't define guidelines what can be broadcast? How about because GM is the largest auto manufacturer we let them decide how cars should be built and what guidelines they should adhere to? Then all of the other manufacturers could just follow along.
Can you imagine what the Internet would be like if we didn't have organized bodies attempting to set a standard everyone can agreed on? Can we say "free for all"? Can you imagine a world without standards? No broadcast TV signal standards, no adherence to a wireless spectrum rules, heck my telephone probably wouldn't even work outside my local calling area. The W3C is attempting to bring the same form of organization to the web and set one common set of rules that make things inter-operate at an expected level. That is in no way a bad goal or a fruitless effort. Nor should it be ignored.
Play me online? Well you know that I'll beat you. If I ever meet you I'll "/sbin/shutdown -h now" you. -Weird Al, kinda.
I can be accused of quoting out of context, but anyone can read Gustafson's post. I fail to accept the logic: "A switch (DOCTYPE) came into existence; its use suggests that the page developer knows what they're doing. Yet, many developers didn't know what they were doing as they used it, and for that, a specific tool is to blame, a very common tool that failed to understand the switch. Ergo, the switch mechanism is flawed."
I'm sure someone can help me understand this logic. Please do.
I speak England very best