質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
CakePHP

CakePHPは、PHPで書かれたWebアプリケーション開発用のフレームワークです。 Ruby on Railsの考え方を多く取り入れており、Railsの高速性とPHPの機動性を兼ね備えています。 MVCやORMなどを「規約優先の考え方」で利用するため、コードを書く手間を省くことができます。 外部のライブラリに依存しないので、単体での利用が可能です。

jQuery

jQueryは、JavaScriptライブラリのひとつです。 簡単な記述で、JavaScriptコードを実行できるように設計されています。 2006年1月に、ジョン・レシグが発表しました。 jQueryは独特の記述法を用いており、機能のほとんどは「$関数」や「jQueryオブジェクト」のメソッドとして定義されています。

Ajax

Ajaxとは、Webブラウザ内で搭載されているJavaScriptのHTTP通信機能を使って非同期通信を利用し、インターフェイスの構築などを行う技術の総称です。XMLドキュメントを指定したURLから読み込み、画面描画やユーザの操作などと並行してサーバと非同期に通信するWebアプリケーションを実現することができます。

Q&A

解決済

1回答

382閲覧

jqueryでのajax化 に関してわからないこと

tou.23.bc

総合スコア50

CakePHP

CakePHPは、PHPで書かれたWebアプリケーション開発用のフレームワークです。 Ruby on Railsの考え方を多く取り入れており、Railsの高速性とPHPの機動性を兼ね備えています。 MVCやORMなどを「規約優先の考え方」で利用するため、コードを書く手間を省くことができます。 外部のライブラリに依存しないので、単体での利用が可能です。

jQuery

jQueryは、JavaScriptライブラリのひとつです。 簡単な記述で、JavaScriptコードを実行できるように設計されています。 2006年1月に、ジョン・レシグが発表しました。 jQueryは独特の記述法を用いており、機能のほとんどは「$関数」や「jQueryオブジェクト」のメソッドとして定義されています。

Ajax

Ajaxとは、Webブラウザ内で搭載されているJavaScriptのHTTP通信機能を使って非同期通信を利用し、インターフェイスの構築などを行う技術の総称です。XMLドキュメントを指定したURLから読み込み、画面描画やユーザの操作などと並行してサーバと非同期に通信するWebアプリケーションを実現することができます。

0グッド

0クリップ

投稿2022/01/18 13:51

編集2022/01/19 08:54

cakephpで簡単なブログを作成しています。
その中で投稿の削除処理をjQueryを使ってajax化をしています。
ボタンをクリックするときちんと投稿は削除されるのですが、かんじんのふわっとした処理が追加されません、

何度も何度もコードを確認しましたが、ミスがみつけられませんでした。

また、function(res)の意味がりかいできないのですが、こちらはどういったいみなのでしょうか?
引数なのでしょうか?

edit.ctp{php(jsを埋め込んでます。)}

1<script> 2 3$(function() { 4 $('a.delete').click(function(e) { 5 if (confirm('sure?')) { 6 $.post('/posts/delete/'+$(this).data('post-id'), {}, function(res) { 7 $('#post_'+ res.id).fadeOut(); 8 }, "json"); 9 } 10 return false; 11 }); 12}); 13 14 15</script>

cakephpのPostscontroller.php

1 public function delete($id) { 2 if ($this->request->is('get')) { 3 throw new MethodNotAllowedException(); 4 } 5 6 if ($this->request->is('ajax')) { 7 if ($this->Post->delete($id)) { 8 $this->autoRender = false; 9 $this->autoLayout = false; // この2つはajax処理をするときの決り文句 10 $response = array('id' => $id); // idをjson形式で返す 11 $this->header('Content-Type: application/json'); 12 echo json_encode($response); 13 exit(); 14 } 15 } 16 $this->redirect(array('action' => 'index')); 17 }

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

ベストアンサー

機能については大抵Web上に公式のマニュアルやドキュメントがあるのでまずは確認することです。(言語やフレームワークも同様)
jQuery.post()

function(res) {}はここだとsuccess に当たる部分。

success
Type: Function( PlainObject data, String textStatus, jqXHR jqXHR )
A callback function that is executed if the request succeeds. Required if dataType is provided, but can be null in that case.

「コールバック引数」と呼ばれるものになります。
機能の処理が成功した結果、機能の実行結果などを受け取る引数です。
今回の場合だとAjax実行先のレスポンスが入ってきているはずです。
それは第4引数dataTypeの形式で返ってきます(特にJSONなど厳密なものである場合、レスポンスの形式が沿ってない場合はエラーとなります)
サーバーサイドの処理が提示されてないのでどういうレスポンス返しているか分かりませんが、resをデバッグで確認してみては。

ふわっとした処理

どうなるのを「ふわっと」と表現されているのか分かりませんが、
現状のコードではそれっぽいのは.fadeOut()しかないです。
こちらは対象要素を徐々にhiddenにしていくアニメーション機能です。
質問内の「ボタンをクリックするときちんと投稿は削除される」という説明から、
この機能が働いているものと思われるので、それ以外のアニメーションはそもそも実装されてないのでは?
(ちなみに先に書いたように「徐々にhiddenにしていく」だけでHTML上には残ってます。本当に削除したいのならfadeOutのコールバックでremove()したほうが良いと思います)

投稿2022/01/18 23:02

m.ts10806

総合スコア80850

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

tou.23.bc

2022/01/19 02:42

丁寧なご回答ありがとうございます。 アドバイス頂いた通り console.log(res);でresをデバッグしようとここと見たのですが、resが定義されていないとエラーがでました。 ということはresが定義できていないのでしょうか? それともデバッグのやり方がまちがっているのでしょうか? よろしくお願いいたします。
m.ts10806

2022/01/19 02:58

どこに書いたのでしょう。 コールバック引数の関数の中ならres.idを参照できてるわけですし、エラーにならないはずですが
tou.23.bc

2022/01/19 05:28

ご回答ありがとうございます。 function(res){}の中にconsole.log(res)をかきました。 ですが、なにもデバックされませんでした。 つまり空だったということなのでしょうか。 現在dotinstallの講座を視聴しながらすすめているのですが、そもそもresという変数名をここ以外で書いたおぼえがありません、また動画を何度もみかえしてもresに関する記述がみつけれません。
m.ts10806

2022/01/19 07:08

ブラウザ開発ツールのコンソール確認しては。 {}内なら定義されてないということにはならないですよ。 念の為質問のコードを更新してもらえますか? ドットインストールやったことないですが、コールバック引数でも変数は任意の名称なので別にresという名前である必要はないです。
tou.23.bc

2022/01/19 08:50

ご回答いただきありがとうございます。 コンソールの方で確認いたしました。 質問のコードなのですがPostscontroller.phpのedit methodのほうを追加で記載させていただきました。 あと、もう一つしつもんさせていただけませんでしょうか fadeOut前の $('#post_'+ res.id)がどうしてもわかりません。。 ここにもresがついていますが、この関数をよびだしている形跡がみあたらないのでいまいち理解ができません。 res.idでおそらくブログページのid(数字)を特定しているというのは理解ができるのですが、 なぜこのような書き方になるのかどうしてもわかりません。 追加で質問させていただく形になってしまいましたが、よろしくお願いいたします。。
m.ts10806

2022/01/19 09:37

あのconsole.log(res)の話をしてるのですが、そこのコードの提示を。 resが保持してる値がわかればなぜ.idで参照できるかわかりますし、Ajaxのリクエストとレスポンスの扱いについては回答に書いています。 というか、自身が書いたコードでないなら出典元に聞くのが確実では。赤の他人には想像しかできないので。
tou.23.bc

2022/01/19 11:12

確かにそのとおりですね。。 丸投げの質問失礼いたしました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問