回答編集履歴

3

コード例追記

2016/03/19 05:03

投稿

unau
unau

スコア2468

test CHANGED
@@ -31,3 +31,41 @@
31
31
  ```
32
32
 
33
33
  最近の PHP や CakePHP はさっぱりわかりませんが、`SampleAction` の中で `$this->render("sample")` しているところで `ob_start` などで出力をバッファリングして、それをレスポンスの JSON に突っ込めばいいと思います。
34
+
35
+
36
+
37
+ ---
38
+
39
+ 実装例
40
+
41
+
42
+
43
+ 最近の PHP, CakePHP の作法は知りませんので、適当にアレンジしていただくとして、私の案の実装例です。未検証なので動くかどうかはわかりませんが。
44
+
45
+
46
+
47
+ 現在、
48
+
49
+ ```PHP
50
+
51
+ $this->render("sample");
52
+
53
+ ```
54
+
55
+ でテンプレートに当てはめて書き出している処理を、
56
+
57
+ ```php
58
+
59
+ ob_start();
60
+
61
+ $this->render("sample");
62
+
63
+ $response = array( 'html' => ob_get_contents(), 'hasNext' => $hasNext );
64
+
65
+ ob_end_clean();
66
+
67
+ echo json_encode($response);
68
+
69
+ ```
70
+
71
+ とするような感じです。

2

追記

2016/03/19 05:03

投稿

unau
unau

スコア2468

test CHANGED
@@ -30,4 +30,4 @@
30
30
 
31
31
  ```
32
32
 
33
-
33
+ 最近の PHP や CakePHP はさっぱりわかりませんが、`SampleAction` の中で `$this->render("sample")` しているところで `ob_start` などで出力をバッファリングして、それをレスポンスの JSON に突っ込めばいいと思います。

1

追記

2016/03/19 00:19

投稿

unau
unau

スコア2468

test CHANGED
@@ -1,3 +1,33 @@
1
1
  `$.ajax()` が成功したときのハンドラ (`.done(function() { ~ } )` でいいのかな)の中で `.append()` で追加していますが、そのときにもっと見るボタンを `.hide()` すればいいのではないでしょうか。
2
2
 
3
3
  あと、ajax では json とか返して `.done()` の中ではそれを表示用に加工しながら追加するほうがいいと思うのですが、CakePHP 界隈では普通どうやるんでしょう。
4
+
5
+
6
+
7
+ ---
8
+
9
+ 追記
10
+
11
+
12
+
13
+ 『「もっと見る」ボタンを押して次に表示すべきリストを ajax でもらってくるけれど、まだ次があって「もっと見る」ボタンを消しちゃいけないときと、その次はないので「もっと見る」ボタンを消すべききがある』
14
+
15
+ ということなのかな、と思い、その線で考えたことを追記します。
16
+
17
+
18
+
19
+ ajax で返すデータはやはり JSON にするといいのではないでしょうか。リストに追加すべき HTML とまだ次があるかどうかを示すフラグが格納されているような。
20
+
21
+ ```json
22
+
23
+ {
24
+
25
+ "html": "~追加すべき HTML データ~",
26
+
27
+ "hasNext": true/false
28
+
29
+ }
30
+
31
+ ```
32
+
33
+