jQuery :: safariとappend関連メモ
2009/9/23 (Wed) at 4:28 pm
気づいたのでメモ。phpで生成したhtml文字列を、ajaxでjsに渡してdomを差し替える(jQuery的にいうempty + appendする)という所作はかなり便利です。なにかのトリガーを元にあーしてこーしてvalidityチェックもやってどーのこーの .... という複雑な文字列生成のところはphpに一括お任せし、Javascript側は出来上がったhtmlを受け取るだけ、それを指定のところにappendして完了。という流れです。
これを積極的に行うことによりJavascriptは軽量になりますし、またJavascriptにおける間違い探しのデバッグ作業を減らすことができるという利点があると思います。私は元々「サーバ側でできることはなるたけサーバ側でやるのだ!」というクライアントに優しいつくりが望ましいという方針なので、その点からいってもいいです。とはいってもものすごく簡単な正規表現チェックなどもいちいちphpを呼び出していたんではトラフィックが増えて冗長なつくりになってしまうので、まぁケースバイケースでしょうけれど。
で、いつものようにその調子でやっていたらば、safariのみで再現される不思議な現象を知りましたのでメモしときます。正確に何バイトなのかは測定してないのですが、とある長大なhtml文字列をjsonでjQueryのメソッドを用いてphp → Javascriptに渡してそれをとあるidにappendするというのをやってたらば、safariの場合のみ、渡す文字列のバイト数が一定量を超えるとうまくappendされなくなるのです。
通常このようなケースは、php側でなにかタコミスをしていて、NOTICEエラーなどが出ていることが多いです。Firebugでajaxで受け取った内容をチェックしたらば、エラーはなく正常に受信している。さらにFirefoxだと意図通りにappendされて表示できている。どうもsafariだけの症状みたい。てか、webkit特有のものかもしれません。
Safariで使えるFirebugてもんは存在しないので(そういうデバッグツールあるんでしょうか?)、こういう場合の間違い探しはむずかしい。とりあえず、phpから受け取ったjsonが正常に受信しているかを知るためにalertで表示してみましたらちゃんときてました。てことはappendする部分でコケている。この場合、受け取る文字数が少ないと正常に動くのです。文字数が一定以上になった場合だけ100%再現されるのです。文字列の中にへんなものが混じっているせいではないかとも思われたので、アルファベットとhtmlタグだけのものも送ってみましたがやはり再現されました。おっかしいなー。
自分が書いたJavascriptのコードをよーく見たらこういうかしょがありました↓
$('#abc').append($(res.html));
$('#def').replaceWith($(res.html));
resオブジェクトはphpから受け取ったデータです。res.htmlにはappendされるべきhtml文字列が入っています。
いままでコレでオッケーだったもんだから深く考えずにこういう書き方をしてしまっていたのです。てか、$('#abc').append($(res.html));でも$('#abc').append(res.html);でもどっちでも動くんで、いったいどちらが正しい書き方なのだろうと不思議だったのですが、今回、$()の囲いをとっぱらって、
$('#abc').append(res.html);
$('#def').replaceWith(res.html);
としましたら、正常に動くようになりました。はぁ。ま、オチとしては私のいいかげんな書き方が原因だったとわかったのですが、一部のブラウザだけ、それも文字数が一定量以上超えたときだけ問題が出てくるなんていうnastyな症状だったので発見に時間がかかってしまいました。
文字の量が多くなると問題が出ると私は書いてますが、もしかしたら別のなにかが原因なのかもしれません。すべての可能性を考えて厳密な再現チェックをしているわけではないのでなにか別の原因だったかもしれないですが、とにかくですね、jQueryのappendやらappendToやらreplaceWithのカッコの中に$(foo)てのを入れると(fooはhtml文字列が代入された変数)へんな具合になることがあるんだなと知った次第です。
コメント・プリーズ!
PROFILE![]()
藤居ヒロヤ。ウェブデザイナー/ウェブディレクター。ウェブデザインオフィス、3OT NET主宰。名古屋市中区。「優しいデザイン」「激しいデザイン」「正しいデザイン」「セクシーなデザイン」「泣けるデザイン」「もっともなデザイン」... 。あなただけのウェブデザインを丹精込めておつくり致します。見積り依頼等、お気軽にお問い合わせ下さい。
- www. http://www.3ot.net/
- email. admin [atmark] 3ot.net
- phone. 052 323 7376
RECENT ENTRIES![]()
- トウモロコシがおいしい
- ダイコクドラッグが近所にできた
- ライブドアのBLOGOSをよく読みます
- jQuery :: 画像のリロード
- タムの絵
- Javascript :: ecl.jsにながらくお世話になりました
- サーバ移転&ブログのデザインをすこし変えました
- php :: 正規表現 :: 名前つきキャプチャというのを習った
- jQuery :: ネストしたリスト + ui.sortable.js
- jQuery :: event delegationてナニ?
RECENT COMMENTS![]()
- トウモロコシがおいしい [4]
- ふ (07/09)
- いら (07/03)
- ふ (07/03)
- いら (07/03)
- php :: ファイルを強制的にダウンロードさせる [9]
- ふ (05/26)
- ふ (05/26)
- ふ (05/26)
- esperia (05/26)
- esperia (05/26)
- ふ (05/25)
- esperia (05/25)
- ふ (04/14)
- とほりすがり (04/13)
- タムの絵 [2]
- ふ (12/05)
- いら (12/04)
TOOLS![]()
- s-box.js
- Link2WikipediaEncoder
- QR_CodeGenerator
- PagerankChecker
- IntrocucePhpCodeOnBlog
- FaviconGenerator
- Whois
- SiteThumbnailGenerator (Beta)
- EmailAddressEncoder (Legacy!)
BOOKMARKS![]()
RESOURCES![]()
- 99designs
- COMPUTER ARTS
- CPAN
- PHP標準関数逆引き辞典
- SMASHING MAGAZINE
- UNIXコマンド
- ajaxload.info
- deviantART
- deviantART :: PS Brushes
- deviantART :: PS Shapes
- fotosearch.com
- hotscripts.com
- hotscripts.com :: php
- iconlet.com
- jQuery Reference
- php.net :: 関数レファレンス
- psbrushes.net
- turnkeyforms.com
ARCHIVE![]()
- 2010年7月 (1)
- 2010年1月 (1)
- 2009年12月 (2)
- 2009年11月 (3)
- 2009年10月 (1)
- 2009年9月 (9)
- 2009年8月 (7)
- 2009年6月 (7)
- 2009年5月 (1)
- 2009年4月 (8)
- 2009年3月 (1)
- 2009年1月 (1)
- 2008年12月 (3)
- 2008年11月 (1)
- 2008年4月 (1)
- 2008年1月 (3)
- 2007年12月 (1)
- 2007年10月 (3)
- 2007年9月 (5)
- 2007年8月 (4)
- 2007年7月 (13)
- 2007年6月 (22)
- 2007年5月 (30)
- 2007年4月 (15)
- 2007年3月 (12)
- 2007年2月 (7)
- 2007年1月 (16)
- 2006年12月 (23)
- 2006年11月 (9)
- 2006年10月 (3)
- 2006年9月 (2)
- 2006年8月 (6)
- 2006年7月 (4)
- 2006年6月 (6)
- 2006年5月 (10)
- 2006年3月 (17)
- 2006年2月 (8)
- すべての投稿 (266)
