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

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

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

Rubyはプログラミング言語のひとつで、オープンソース、オブジェクト指向のプログラミング開発に対応しています。

Ruby on Rails

Ruby on Railsは、オープンソースのWebアプリケーションフレームワークです。「同じことを繰り返さない」というRailsの基本理念のもと、他のフレームワークより少ないコードで簡単に開発できるよう設計されています。

JavaScript

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

jQuery

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

Q&A

解決済

1回答

998閲覧

jqueryの非同期通信について

Raleigh

総合スコア8

Ruby

Rubyはプログラミング言語のひとつで、オープンソース、オブジェクト指向のプログラミング開発に対応しています。

Ruby on Rails

Ruby on Railsは、オープンソースのWebアプリケーションフレームワークです。「同じことを繰り返さない」というRailsの基本理念のもと、他のフレームワークより少ないコードで簡単に開発できるよう設計されています。

JavaScript

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

jQuery

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

0グッド

1クリップ

投稿2020/05/23 03:40

編集2020/05/23 06:28

前提・実現したいこと

jqueryで非同期通信を使うときの質問です。
自分はいつも、以下のような方法で投稿内容の保存と表示をしています。
以下は自分の簡単なメモの投稿と表示をするコードの一部です。

投稿画面とメモの表示

html

1<%= form_for @memo, remote: true do |f| %> 2 <%= f.text_field :text %> 3 <%= f.submit '投稿' %> 4<% end %> 5<ul> 6 <%= render @memos %> 7</ul>

変更後のメモのレコードを挿入

javascript

1$("#memo_text").val(""); // 入力フォームを空欄にする処理 2$("ul").html("<%= j(render @memos) %>");

メモのテキスト表示の部分テンプレート

html

1<li> 2 <%= memo.text %> 3</li>

コントローラの記述

ruby

1class MemosController < ApplicationController 2 def index 3 @memos = Memo.all 4 @memo = Memo.new 5 end 6 7 def create 8 Memo.create(memo_params) 9 @memos = Memo.all 10 end 11 12 def destroy 13 Memo.find(params[:id]).destroy 14 @memos = Memo.all 15 end 16 17 private 18 def memo_params 19 params.require(:memo).permit(:text) 20 end 21end

 しかし、これだと部分テンプレートのファイルが勝手に「memos/_memo.html.erb」になってしまい、自分で指定することができず、困っています。

 部分テンプレートを指定できかつ、非同期通信ができるコードの書き方のアドバイスをください。
よろしくお願いします。

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

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

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

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

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

m.ts10806

2020/05/23 03:46

これは非同期うんぬんよりRuby on Railst特有の話では。 タグを追加してください。※私はそもそもRuby詳しくないので回答できませんが
Raleigh

2020/05/23 03:50

指摘ありがとうございます。
miyabi_takatsuk

2020/05/23 06:24

jQueryの処理を、Ruby on Railsの処理を通さないのであれば、 Ruby on Rails記載ではなく、HTMLまんまのコードにする必要があると思いますよ。
guest

回答1

0

ベストアンサー

部分テンプレートのファイルが勝手に「memos/_memo.html.erb」になってしまい、自分で指定することができず、困っています。

この部分の回答になりますが、確か...

erb

1render @memos

erb

1render partial: 'memos/memo', collection: @memos

の省略だったと思います。なので...

erb

1$("ul").html("<%= j(render partial: 'template/name', collection: @memos) %>");

こんな感じで書けるはずです。

投稿2020/05/25 04:43

Mugheart

総合スコア2342

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

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

Raleigh

2020/05/25 05:17

解決しました! ありがとうございます
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.49%

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

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

質問する

関連した質問