メモから来ているので、各エントリのタイトルと文法的特徴のみをリストします。当面は詳細な説明と実行可能な例を書く時間がありませんが、関連するドキュメントのアドレスもリストします。すでにこの機能をサポートしているブラウザーは、サポートされていないブラウザー用の代替/移行実装も提供します。そうですね、これは元々私が個人的にメモしたもので、私は Evernote にメモをとるのが特に好きです。前回 Lewu 先生の記事を見たときに、私は今の年齢がちょうど記憶力のピークに入ったばかりだと言いましたが、私自身。自信にはまだまだ力が要ります!たとえば、『ダークナイト』でピエロが病院で検察官に何を言ってトゥーフェイスになったのかについて他の人たちと議論しているとき、セリフを一行も思い出せなかったし、ペニーがエイジを演じたときのキャラクターの名前は何だったのか。ビッグバンセオリーS2のコナンの「女王ペネロペ」、見たときは感動しすぎて1ヶ月後にはオデッセイのことすら覚えてなかった。メモを残すといつも気持ちが楽になります…あ、また話が逸れてしまいました。
この記事では、最も重要な (または比較的人気のある) 新しい標準のいくつかをまとめました。それらのほとんどはまだ w3c の草案であり、推奨レベルの初期段階にありますが、新しい標準ラウンドでは非常に人気が高まっています。有名なブラウザ戦争では、開発者コミュニティに多数の関連デモや API パッケージが登場し、一部は実稼働環境に参入しています (iPhone 上の Google の Gmail オフライン アプリケーションなど)。メーカー独自のテクノロジーから、キラーアプリケーションを生み出すために委員会の標準を汎用テクノロジーに変換するサイクルが大幅に加速されているのは、Web アプリケーションの需要が高すぎるためでしょうか... 更新: 。先ほど Solidot にソフト記事を投稿したときにふと思いました。この問題をどのように表現するかを理解してください。実際、多くのブラウザ メーカーは、ステージを構築するエンジニアがブラウザのアクターでもあるのと同じように、ブラウザ ベースのアプリケーション開発者であり、Web 標準の設定者でもあります。 Google、Mozilla、Apple は、まだ W3C Working Draft 段階にあるにもかかわらず、Web アプリケーションの開発に役立つ技術標準を実装するために努力を惜しんでいません。計画経済には活力が欠けています XD...
メモから派生したものなので、各エントリのタイトルと文法的特徴のみをリストします。当面は詳細な説明と実行可能な例を書く時間がありませんが、関連するドキュメントのアドレスを記載します。この機能でサポートされているブラウザーのリストに加えて、この機能をサポートしていないブラウザーに対する代替/移行の実装も提供されます。
===================ナンセンスが終わる境界線====================== ==
外部リンク CSS ファイル全体と CSS コードの一部のメディア タイプ検出。その高い人気の理由は明らかにモバイル デバイスにあります。
w3c 標準: http://www.w3.org/TR/css3-mediaqueries/
MDC ドキュメント: https://developer.mozilla.org/En/CSS/Media_queries
Opera ドキュメント: http ://www.opera.com/docs/specs/css/
サポート: Firefox 3.5、Safari 3、Opera 7
CSS変形、疑似3D効果や回転効果を実現するためにこのjqueryプラグインを使用する人もいます
w3c 標準: http://www.w3.org/TR/css3-2d-transforms/
MDC ドキュメント: https://developer.mozilla.org/En/CSS/CSS_transform_functions
Webkit ブログはじめに: http://webkit.org/blog/130/css-transforms/
サポート: Firefox 3.5、Safari 3.1
代替/移行: IE5.5 マトリックス フィルター http://msdn.microsoft.com/en-us/library/ms533014(VS) .85).aspx
Webkit チームによって提案されたドラフトである待望の CSS アニメーションでは、トランジションは単純な属性グラデーションを実装し、アニメーションはより複雑なアニメーション効果を定義します
w3c 標準: http://www.w3.org/TR/css3-transitions/
w3c 標準: http://www.w3.org/TR/css3-animations/
Webkit ブログ はじめに: http://webkit.org/blog/138/css-animation/
クラスメートのジョンからの紹介: http://ejohn.org/blog/css-animations-and-javascript/
サポート: Safari 3.1
Web ページに任意のフォントを埋め込むことができるのはデザイナーの夢です...しかし、ここでサポートされているのは TrueType と OpenType だけです
w3c 標準: http://www.w3.org/TR/css3-fonts/#font-resources
MSDN ドキュメント: http://msdn.microsoft.com/en-us/library/ms530303( VS.85).aspx
MDC ドキュメント: https://developer.mozilla.org/en/CSS/@font-face
サポート: Firefox 3.5、Safari 3.1、Opera 10.0、IE4.0
ppk の学生が管理するドキュメント: http://www.quirksmode.org/css/contents.html
css3.info が管理するドキュメント: http://www.css3.info/modules/selector-compat/
テストページ: http://westciv.com/iphonetests/
キーと値のペアの形式の単純な永続ストレージ
w3c 標準: http://www.w3.org/TR/webstorage/
ppk クラスメートによって維持される互換性リスト: http://www.quirksmode.org/dom/html5.html#localstorage
MDC ドキュメント: https://developer.mozilla.org/en/DOM/Storage
MSDN ドキュメント: http://msdn.microsoft.com/en-us/library/cc197062(VS.85).aspx
サポート: Firefox 3.5、Safari 4.0、IE 8.0
構造化データではなく、マニフェスト ファイルを使用して、オフラインで使用できる静的リソース (画像、CSS、JS など) をキャッシュします
w3c 標準: http://www.w3.org/TR/offline-webapps/#offline
MDC ドキュメント: https://developer.mozilla.org/en/Offline_resources_in_Firefox
サポート: Firefox 3.5
SQL をサポートするローカル データベースは、Google Gears によって最初に実装されました。現在の w3c ドラフトの編集者も Google エンジニアです...しかし、奇妙なことに、Gears API は現在のドラフトと互換性を持たないことさえ望んでいます。バンドルされている Gears は、データベース API が Webkit で実装された HTML5 API を削除しました...そして、Google が iPhone に Gmail オフライン機能を実装したとき、Webkit API も使用していました... それは本当に混乱しています...
w3c 標準: http://www.w3.org/TR/offline-webapps/#sql
Webkit ブログの紹介: http://webkit.org/blog/126/webkit-does-html5- client-side-database-storage/
iPhone ドキュメント: http://developer.apple.com/documentation/iPhone/Conceptual/SafariJSDatabaseGuide/UsingtheJavascriptDatabase/UsingtheJavascriptDatabase.html#//apple_ref/doc/uid/TP40007256-CH3 - SW1
サポート: Safari 3.1
代替/移行: Gears http://code.google.com/p/gears/wiki/Database2API
複数のスレッド、バックグラウンドで複雑な操作を実行、DOM を操作できない、メッセージ イベントを通じてスレッド間で通信
w3c 標準: http://www.w3.org/TR/workers/
MDC ドキュメント: https://developer.mozilla.org/En/Using_web_workers
サポート: Firefox 3.5
代替/移行: Gears http://code.google.com/p/gears/wiki/HTML5WorkerProposal
地理 API
w3c 標準: http://www.w3.org/TR/geolocation-API/
MDC ドキュメント: https://developer.mozilla.org/En/Using_geolocation
サポート: Firefox 3.5
代替/移行: Gears http://code.google.com/p/gears/wiki/GeolocationAPI
ネイティブドラッグイベント
w3c 標準: http://www.w3.org/TR/html5/editing.html#dnd
MDC ドキュメント: https://developer.mozilla.org/En/DragDrop/Drag_and_Drop
appleドキュメント: http://developer.apple.com/documentation/AppleApplications/Conceptual/SafariJSProgTopics/Tasks/DragAndDrop.html#//apple_ref/doc/uid/30001233
サポート: Firefox 3.5、Safari 2.0、Chrome 1.0、IE 5.0
HTML タグを使用してビデオとオーディオを埋め込む利点は、「オープンソース形式」ではなく、マルチメディアが他のページ要素と対話したり、ページテクノロジーを使用してビデオと「マッシュアップ」したりできる「オープン性」です。ランダムな組み合わせの一種 RIA と対話できる機能は、Web テクノロジーの繁栄の基礎ですが、フラッシュのようなクローズド RIA コンテナーの最大の欠点でもあります。
MDC ドキュメント: https://developer.mozilla.org/En/Using_audio_and_video_in_Firefox
Webkit ブログの紹介: http://webkit.org/blog/140/html5-media-support/
サポート: Firefox 3.5、Safari 3.0、Chrome 3.0
代替/移行: video タグを使用したネストされた埋め込み http://hacks.mozilla.org/2009/06/html5 - video-fallbacks-markup/
Apple によって発明され、現在主流の js 画像技術であるダッシュボードで最初に使用され、mozilla はすでに OpenGL ES 標準の Canvas 3D を実装しています。さらに、IE チームは Canvas をサポートするために多くの作業を行っていると言われています。実際、キャンバス API は非常に低レベルであり、特にインタラクションの点では svg ほど直感的ではないため、それをカプセル化するライブラリが多数あります。
サポート: Firefox 1.5、Safari 2.0、Chrome 1.0、Opera 9.0
代替/移行: excanvas.js http://code.google.com/p/explorercanvas/
IBM DW チュートリアル: http://www.ibm.com/developerworks/cn/views/xml/tutorials.jsp?cv_doc_id =84896
サポート: Firefox 1.5、Safari 3.0、Chrome 1.0、Opera 9.0
代替/移行: raphael.js http://raphaeljs.com/
w3c 標準: http://www.w3.org/TR/XMLHttpRequest2/
MDC ドキュメント: https://developer.mozilla.org/En/Using_XMLHttpRequest#Monitoring_progress
XDomainRequest (XDR)
MSDN ドキュメント: http://msdn.microsoft.com/en-us/library/cc288060(VS.85).aspx
サポート: Firefox 3.5 (部分的に実装)、IE 8.0 (部分的に実装)
w3c 標準: http://www.w3.org/TR/cors/
MDC ドキュメント: https://developer.mozilla.org/En/HTTP_Access_Control
クロスドキュメント メッセージング (XDM)
MSDN ドキュメント: http://msdn.microsoft.com/en-us/library/cc197057(VS.85).aspx
サポート: Firefox 3.5、IE8.0
Firefox と ActionScript3 はすでに何かを実装しています...しかし実際には、JSON がこれほど普及している今、E4X の有無は関係ないようです ~ (ナンセンス、実際には次のように書くと便利です) HTML 文字列の代わりに js コードで直接 dom オブジェクトを作成) たくさん)
MDC ドキュメント: https://developer.mozilla.org/en/E4X
サポート: Firefox 1.5
ネイティブ JSON サポートは eval より 100 倍高速で安全です。また、Douglas Crockford の json2.js は js で実装された js インタープリターであるため、より安全であることにも注意してください。
MDC ドキュメント: http://blog.mozilla.com/webdev/2009/02/12/native-json-in-firefox-31/
MSDN ドキュメント: http://blogs.msdn.com/ ie/archive/2008/09/10/native-json-in-ie8.aspx
サポート: Firefox 3.5、IE8
代替/移行: json2.js http://www.json.org/json2.js
js1.6で実装されている配列メソッドは主に、関数型プログラミングにおいて非常に重要なメソッドであるforEach、map、filterと、リバースクエリです
MDC ドキュメント: https://developer.mozilla.org/en/New_in_JavaScript_1.6#Array_extras
サポート: Firefox2.0、Safari 3.0、Google Chrome 1.0、Opera 9.5
代替/移行: Array.prototype を拡張することですべてシミュレート可能
配列とオブジェクトを区別する
代替/遷移: Array.isArray = function(a){ return Object.prototype.toString.call(a) === "[オブジェクト配列] ”;};
ECMAScript 5 オブジェクト
クラスメイトのジョンの説明: http://ejohn.org/blog/objectgetprototypeof/
サポート: Firefox3.5
代替/移行: object.__proto__ または object.constructor.prototype
クラスメイトのジョンの説明: http://ejohn.org/blog/ecmascript-5-objects-and-properties/
サポート: なし
置換/移行: Object.create と Object.keys は自分で実装できます
オブジェクトプロパティのアクセス制御
クラスメイトのジョンの説明: http://ejohn.org/blog/ecmascript-5-objects-and-properties/
サポート: なし
置換/遷移: Object.defineProperties は実際には jQuery.extend と同等であり、Mixin の実装に使用されます
Python と Ruby の両方の属性アクセス メソッド
代替/移行:
Firefox 1.5 の非標準の古いメソッド
標準
Dokumentasi MSDN: http://msdn.microsoft.com/en-us/library/dd229916(VS.85).aspx
Sokongan: IE8 (hanya boleh digunakan dengan DOM)
Mod ketat ES5 memadamkan elemen yang mungkin menyebabkan masalah dalam versi lama dan akan melaporkan ralat secara jelas untuk memudahkan penyahpepijatan
Penjelasan rakan sekelas John: http://ejohn.org/blog/ecmascript-5-strict-mode-json-and-more/
Sokongan: Tiada
Alternatif/Peralihan: ... Mula membangunkan tabiat pengaturcaraan yang serius dari sekarang
Apabila menghantar rujukan kepada fungsi, ikat ini
Sokongan: Tiada
Alternatif/Peralihan: prototaip http://www.prototypejs.org/api/function/bind
Tarikh berformat ISO
Disokong: Tiada
Alternatif/Peralihan: datejs http://code.google.com/p/datejs/
Sokongan: Firefox3.5
Alternatif/Peralihan: Pelbagai pelaksanaan biasa http://blog.stevenlevithan.com/archives/faster-trim-javascript
================================ Garis pemisah di mana perkara karut bermula semula ==== = =====
Sebenarnya perkara ini saya siarkan dengan harapan dapat mempromosikan suasana inovasi dan menyedarkan lebih ramai orang bahawa banyak teknologi baru telah memasuki peringkat "praktikal".
Jika anda hanya mahu membuat permainan web percubaan, atau aplikasi yang hanya boleh digunakan pada platform tertentu (seperti iPhone, greasemonkey), sokongan firefox3.5 webkit sudah memadai.
Jika anda tidak boleh mengabaikan platform arus perdana, terdapat banyak teknologi yang membolehkan anda merendahkan atau memilih kaedah yang berbeza untuk melaksanakan antara muka yang serasi.
Jika anda tidak sabar menunggu IE , sebagai contoh, warisan dan kawalan akses objek ES5 telah ditukar daripada kata kunci lama dalam tempoh ES4/ActionScript3 (kelas melanjutkan statik peribadi) kepada Object.create(p , attrs).defineProperty(o, n, attrs).defineProperties( o, attrs).freeze().getOwnPropertyNames().map(fn), ia bukan sahaja untuk kesejukan...
Ramai orang suka merungut "Saya tidak pernah berpeluang menggunakan HTML5 dalam hidup saya", tetapi selagi anda mengalihkan pandangan dari tapak tangan besar di bawah kaki anda dan melihat ke tempat lain, anda akan mendapati bahawa dunia sebenarnya sedang berubah sepanjang masa XD