HTML5でコーディングしたページでjQueryを使うときに気をつけること
そろそろHTML5でコーディングする機会も増えてきたりするかもしれませんが、どうしてもブラウザ対応はしておきたいもの。jQueryで(※)要素をごにょごにょする際にちょっとはまったので一応書いておきます。
IE8以下での話ですが、IE8以下でHTML5を利用するときはHTML5の要素にCSSが適用されないので、html5.jsのようなスクリプトをヘッダで読み込ませたりすると思います。
ちなみに僕はわざわざ読み込むのもアレなので、以下のものを毎回貼ってます。
こんな感じでJavaScriptのcreateElementメソッドでHTML5の要素を追加すれば、CSSが使えるようになって見た目もだいたいばっちりになるんですけど・・・
jQueryで
$(hoge).append('セクション ')
とか
$(hoge).append([ '', ' ' ].join(''));', '', ' ', // hogehoge '', 'タイトル
', 'サブタイトル
', '', '
とか
hogehogehoge
を
var hogeClone = $('#hoge'); $('body').append(hogeClone);
とか(コードの内容に意味はないです)するとCSSが適用されない訳ですよ。つまりページロード時にはcreateElementで要素を作ってるんだけど、それ以降に新しく追加されたりしたHTML5の要素にはcreateElementしてたやつは効果がないっぽい。
単純に上に書いたようなDOM操作なら、ちょっとめんどいけど
$(hoge).append(document.createElement('section'))
みたいにすればよさそう。でもAjaxでとってきたページにHTML5の要素が含まれててそいつらを追加すると、なんかどうやってもうまくいかなかった。
そんなわけでAjax使うところはHTML5の要素を入れなかったりしてます。でもAjaxなくても毎回createElementとかあほらしいし、そういう処理使う場合はHTML5の要素は使わない方がいいんじゃないですかね。
とか言いながら使いまわせるメソッドとかスニペットとかあればそれでいいのかも。
11:43 追記
対応方法と原因を曖昧にしていた(だめっぽいとかいけるっぽいとか・・・)ので、Webtech Walkerさんの記事へのリンクを追記します。
HTML5の新要素をjQueryでappendとかするとバグる件 – Webtech Walker
jQueryのappend、after等の要素追加メソッドで使うときはinnershiv.jsを利用すればだいたい大丈夫です。
まとめ
つまり何が言いたかったかというと
jQueryぷるぎんって要素をclone()メソッドでコピーしたりなんか色々DOM要素をごにょごにょしたりするやつもあったりするので(僕が作ったやつにもあるんですけど・・・)何気なく使ってる人はそういうこともあるっていう事を知っておかないと、CSSあたらへんねん!意味わからん!とかになったりしそうなので気をつけておかないとなぁーっていうことです。
これくらいはjQueryでネイティブに対応してほしいですね。。
※)jQueryというかJavaScriptですが
Trackbacks: 2
- Trackback URL for this entry
- Listed below are links to weblogs that reference
- HTML5でコーディングしたページでjQueryを使うときに気をつけること from 5509
-
pingback from はじめてHTML5でコーディングする時に注意したいアウトラインとかいろいろ [...] 参考:5509.me HTML5でコーディングしたページでjQueryを使うときに気をつけること ↑ HTML5 注意書き目次へ [...]
-
trackback from code up jQuery 1.7
jQuery 1.7が公開されています。
1.6の時のような互換性を損なうバージョンアップではなく、パフォーマンス改善、機能の統合、外部ライブラリとの共存の改善、等が主なリリース内容で…
Leave a comment