[解決済み] HTML 4とHTML 5の決定的な違いは何ですか?
質問
との主な違いは何ですか? HTML4 と HTML5ドラフト ?
変更された構文や追加・削除されたhtml要素に関連する回答はそのままにしておいてください。
解決方法は?
HTML5には、HTML4と異なるいくつかの目標があります。
不正なドキュメントの処理における一貫性
主なものは 一貫性のある、定義されたエラー処理 . ご存知のように、HTMLは意図的に「タグスープ」をサポートしています。つまり、不正なコードを書いても、それを有効な文書に修正させることができるのです。 問題は、これを行うためのルールがどこにも書かれていないことです。 新しいブラウザベンダーが市場に参入しようとする場合、様々なブラウザ(特にIE)で不正な文書をテストし、そのエラー処理をリバースエンジニアリングすればよいのです。 そうしなければ、多くのページが正しく表示されません(ネット上のページの約90%は、少なくとも何らかの不正を犯していると推定されます)。
そこでHTML5では、このエラー処理を発見し、コード化することで、ブラウザ開発者全員が標準化し、一貫した表示を行うために必要な時間とコストを大幅に削減しようとしているのです。 また、HTMLが文書フォーマットとして消滅した後も、長い将来にわたって歴史学者が私たちの文書を読みたがる可能性があり、完全に定義された解析アルゴリズムがあれば、これを大いに支援できます。
Webアプリケーションの機能向上
HTML5の第二の目標は、HTML、CSS、Javascriptによって、ブラウザがアプリケーションのプラットフォームとなる能力を開発することです。 現在(HTML4では)FlashやJSベースのハックである多くの要素が、言語に直接追加されています。
<canvas>
,
<video>
および
<audio>
. ローカルストレージ(jsでアクセス可能なブラウザ内蔵のキーバリューデータベースで、クッキーが保持できる範囲を超えて情報を保存します)、ブラウザが簡単なユーザーインターフェースを公開できる日付などの新しい入力タイプ(jsベースのカレンダー日付ピッカーは必要ありません)、ブラウザがサポートするフォーム検証などの便利なものは、開発者にとってウェブアプリケーションの開発をより簡単にし、ユーザーにとってもより速くします(多くのものが、javascriptでハックするのではなくネイティブでサポートされているからです)。
要素セマンティクスの改善
HTML5 では他にも多くの小さな取り組みが行われており、例えば、既存の要素 (
<strong>
と
<em>
は実際には別のものを意味し、さらに
<b>
と
<i>
は曖昧なセマンティクスを持っていますが、レガシーなドキュメントをパースする際にはうまく機能するはずです)、そして有用なセマンティクスを持つ新しい要素を追加することです。
<article>
,
<section>
,
<header>
,
<aside>
および
<nav>
の大部分を置き換える必要があります。
<div>
はウェブページで使用され、あなたのページをもう少しセマンティックにしますが、より重要なことがあります。
読みやすい
. もう、あのランダムな
</div>
が閉じている代わりに、明らかな
</header>
または
</article>
これにより、文書の構造をより直感的に理解することができます。
関連
-
iframeフレームワークの使用
-
[解決済み] HTML5のlocalStorageにオブジェクトを格納する方法は?
-
[解決済み] 画面サイズ、現在のウェブページ、ブラウザウィンドウのサイズを取得する
-
[解決済み] PHPでHTML/XMLをパースして処理する方法とは?
-
[解決済み] HTMLのid属性に有効な値は何ですか?
-
[解決済み] How can I set the default value for an HTML <select> element?
-
[解決済み] div内の要素を縦に並べるにはどうしたらいいですか?
-
[解決済み] HTMLのid属性とname属性の違い
-
[解決済み] HTML5で(非空白の)自己閉鎖タグは有効ですか?
-
[解決済み] [Solved] What's the difference between <b> and <strong>, <i> and <em>?
最新
-
nginxです。[emerg] 0.0.0.0:80 への bind() に失敗しました (98: アドレスは既に使用中です)
-
htmlページでギリシャ文字を使うには
-
ピュアhtml+cssでの要素読み込み効果
-
純粋なhtml + cssで五輪を実現するサンプルコード
-
ナビゲーションバー・ドロップダウンメニューのHTML+CSSサンプルコード
-
タイピング効果を実現するピュアhtml+css
-
htmlの選択ボックスのプレースホルダー作成に関する質問
-
html css3 伸縮しない 画像表示効果
-
トップナビゲーションバーメニュー作成用HTML+CSS
-
html+css 実装 サイバーパンク風ボタン
おすすめ
-
[解決済み] HTMLとCSSによるテーブルスクロール [重複]について
-
[解決済み] CSSでcellpaddingとcellspacingを設定する?
-
[解決済み] Webフォームのフィールド/入力タグでブラウザのオートコンプリートを無効にするにはどうすればよいですか?
-
[解決済み] CSSでテキストや画像の背景を透明にするには?
-
[解決済み] リンクのように動作するHTMLボタンを作成する方法
-
[解決済み] <meta charset="utf-8"> vs <meta http-equiv="Content-Type">.
-
[解決済み] How do I style a <select> dropdown with only CSS?
-
[解決済み] input type="date "のフォーマットを変更する方法はありますか?
-
[解決済み] 入力フィールドに :before や :after 疑似要素を使用できますか?
-
[解決済み] 検索エンジンはAngularJSアプリケーションをどのように扱っているのか?