表題について、以下のような場合、htmlで返すのが適切だと思うのですがいかがでしょうか?
###実現したい仕様
初回アクセス時のレスポンスが以下のようなものとします。
<html> <head></head> <body> <ul> <li>データ1</li> <li>データ2</li> <li>データ3</li> </ul> </body> </html>
その後、ajax通信によりページ遷移無しでデータ4以降が読み込まれます。
<html> <head></head> <body> <ul> <li>ツイート1</li> <li>ツイート2</li> <li>ツイート3</li> <li>ツイート4</li> <li>ツイート5</li> <li>ツイート6</li> ... </ul> </body> </html>
###上記を実現する方法A
jsonで受け取り、jsでhtmlに形成してappend。
$.ajax({ url: 'hoge.php', dataType: 'json' }).done(function(json) { // json : ["データ4","データ5","データ6"] json.forEach(function(e) { $('ul').append($('<li>').append(e)); }); });
###上記を実現する方法B
サーバーでhtmlに形成し、jsはappendするだけ。
$.ajax({ url: 'hoge.php', dataType: 'html' }).done(function(html) { // html : <li>データ4</li><li>データ5</li><li>データ6</li> $('ul').append(html); });
###Bの方が良いのでは?
上記2つのうち、フロントの方に求められるレスポンスは圧倒的にAのjson形式が多いように思います。
初回レスポンスは当然htmlなのに、ajaxで追加データ、となった途端にjson形式が好まれるのは何故でしょうか?
今回の場合、Aだとデータをhtml化する処理がサーバーにもフロントにも作られることになってしまいイマイチな気がします。
jsonの方がデータ量が少ないとしても、その分jsにデータをhtml化する処理を追加しなければいけませんし、よほど大きなデータを頻繁にやりとりするサイトでなければこの点で優位になるようには思えません。
また、jsonなら、<li>で囲む以外にもフロント次第で<div>にしたりと色々な場面へ展開できますが、パターンが限られているなら、GETパラメータなりでhoge.php内を分岐させればいいと思います。
###もしjsでhtml化したい場合
最近の流行りでもありますが、データ1~3含め全てをjsがhtml化するとします。
しかし、これを実現するために、初回レスポンスの直後に再びajax通信でサーバへjsonデータをリクエストしているのを見かけますが、無駄に通信回数が増えているように感じます。
初回レスポンスの時点で初期表示に必要なjson文字列をhtml内にインクルードして返すのではだめなのでしょうか?
<script>var data = ["データ1","データ2","データ3"];</script>
###質問のまとめ
長くなって申し訳ありません。まとめると以下2点についてご意見を頂きたいです。
- 今回の例の場合、Bの方法のようにhtml形式でやりとりするのが適切な気がするのですがいかがでしょうか?
- 初回表示の3件もjsonで受け取るにしても、わざわざajax通信せずにhtml内にインクルードすればいいと思うのですがいかがでしょうか?
よろしくお願いたします。
回答6件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。