Знаете ли вы о каких-либо различиях в обработке тегов / свойств HTML в разных браузерах? Например, однажды я видел страницу с тегом ввода с полем максимальной длины, установленным на «2o». Firefox и Opera игнорируют "o" и устанавливают максимальную длину равной 2, тогда как Internet Explorer полностью игнорирует это поле. Вы знаете что-нибудь еще?
(Примечание: поскольку это, вероятно, будет список, было бы здорово, если бы общее название различия было выделено жирным шрифтом, например: Различная ошибочная обработка значений в свойствах тегов)






Проверить http://www.quirksmode.org/
Если вы программируете на javascript, лучший совет, который я могу дать, - использовать библиотеку javascript вместо того, чтобы пытаться свернуть свою собственную. Библиотеки хорошо протестированы, и более вероятно, что встречались угловые случаи.
Scriptalicious - http://script.aculo.us/
jQuery - http://jquery.com/
Microsoft AJAX - http://www.asp.net/ajax/
Додзё - http://dojotoolkit.org/
Прототип - http://www.prototypejs.org/
YUI - http://developer.yahoo.com/yui/
Меня действительно раздражает сломанная функция javascript document.getElementById IE - в большинстве браузеров это даст вам что-то с указанным вами идентификатором, IE с радостью предоставит вам то, что имеет значение в атрибуте name, даже если есть что-то позже в документе с идентификатором, который вы просили.
Списки ошибок
Веб-разработчики уже составили довольно исчерпывающие списки; Я думаю, что лучше составить список ресурсов, чем дублировать эти списки.
Javascript
Я согласен с Крейг - лучше всего программировать Javascript с помощью библиотеки, которая обрабатывает различия между браузерами (а также упрощает такие вещи, как пространство имен, обработка событий AJAX и контекст). Вот переход к ответу Крейга (на этой странице).
Сброс CSS
Сброс CSS действительно может упростить веб-разработку. Они переопределяют настройки, которые немного различаются в разных браузерах, чтобы дать вам более общую отправную точку. Мне нравится Yahoo's YUI Сбросить CSS.
Do you know of any differences in handling HTML tags/properties in different browsers
Этот вопрос запрашивает информацию обо всех различиях, включая DOM и CSS? Немного большая тема. Я думал, что OP спрашивал конкретно о поведении HTML, а не обо всем остальном ...
I once saw a page with a input tag with a maxlength field set to "2o".
В этом конкретном случае вы говорите о коде инвалид. Атрибут maxlength не может содержать буквы, только цифры.
Что браузеры делают с недопустимым кодом, сильно различается, как вы сами можете убедиться.
Если вы действительно спрашиваете, «что делают все разные браузеры, когда сталкиваются с HTML-кодом, который по любой из бесконечного числа причин не работает?», То в этом заключается безумие.
Мы можем значительно сократить проблемное пространство с помощью используя действующий код.
Итак, используйте действительный HTML. Тогда у вас остаются две основные проблемные области:
Несогласованный анализ XHTML в режиме HTML
Парсеры HTML не предназначены для обработки XML.
Если XHTML-документ обслуживается как «text / html», а рекомендации по совместимости не соблюдается, вы можете получить неожиданные результаты.
Empty tags is one possible source of problems.
Например, Opera и IE обрабатывают <br> как два <br>, а Firefox и WebKit рассматривают <br> как один <br>.
URL-адрес «перехода к ответу Крейга» указывает на «beta.stackoverflow.com», а не на «stackoverflow.com». В результате мой браузер (Safari 4) пытается перейти на «beta.stackoverflow.com», но затем перенаправляется на «stackoverflow.com» и теряет хеш ... Однако я не уверен, что URL-адрес необходим в первую очередь - у вас должна быть возможность просто написать хеш: ''.