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

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

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

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

Ajax

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

Q&A

1回答

5973閲覧

ajaxのエラーに関して

987654321

総合スコア28

Ruby on Rails

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

Ajax

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

0グッド

0クリップ

投稿2020/05/13 03:14

編集2020/05/13 08:08

前提・実現したいこと

ブログがあり、ブログのコメントを自動更新で取得しようと思っております。
ブログのコメント画面に遷移すると、
コンソールとターミナルに下記のエラーが出てしまいます。
rails routesで blog_api_blogcomments GET /blogs/:blog_id/api/blogcomments(.:format) api/blogcomments#index {:format=>"json"}
と表示されているのでurlはapi/blogcommentsと記載しました。
ですがターミナルのエラーに
(No route matches [GET] "/blogs/api/blogcomments")
となってしまします。

お分かりになる方がいらっしゃいましたら、ご教授いただけたらと思います。
宜しくお願いいたします。

発生している問題・エラーメッセージ

ターミナル

Started GET "/blogs/api/blogcomments?id=12" for ::1 at 2020-05-13 11:57:23 +0900 ActionController::RoutingError (No route matches [GET] "/blogs/api/blogcomments"):

コンソール

Failed to load resource: the server responded with a status of 404 (Not Found)

該当のソースコード

blogcomment.js

jquery

1 var reloadBlogcomments = function(){ 2 var last_blogcomment_id = $('.blog--comments__box__comment:last').data("blogcomment-id"); 3 $.ajax({ 4 url: "api/blogcomments", 5 type: 'GET', 6 dataType: 'json', 7 data: {id: last_blogcomment_id} 8 }) 9 .done(function(blogcomments){ 10 if (blogcomments.length !== 0){ 11 var insertHTML = ""; 12 $.each(blogcomments, function(i, blogcomment){ 13 insertHTML += buildHTML(blogcomment) 14 }); 15 $('.blog--comments__box').append(insertHTML); 16 $('.blog--comments__box').animate({ scrollTop: $('.blog--comments__box')[0].scrollHeight}); 17 } 18 }) 19 .fail(function() { 20 alert('error'); 21 }); 22 };

api/controllers/api/blogcomments_controller.rb

rails

1class Api::BlogcommentsController < ApplicationController 2 def index 3 blog = Blog.find(params[:blog_id]) 4 last_blogcomment_id = params[:id].to_i 5 @blogcomments = blog.blogcomments.includes(:user).where("id > ?", last_blogcomment_id) 6 end 7end

route.rb

resources :blogs do resources :blogcomments, only: :create namespace :api do resources :blogcomments, only: :index, defaults: { format: 'json' } end

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

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

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

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

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

maisumakun

2020/05/13 03:29

ルーティングはどのように設定していますか?
987654321

2020/05/13 03:32

質問欄にルーティングを記載いたしました。 宜しくお願いいたします。
guest

回答1

0

ルーティングが正しくありません。

内側のresources :blogcomments, only: :indexは、/blogs/:blog_id/api/blogcommentsのようなルーティングを生成しています。メッセージの通り、/blogs/api/blogcommentsというURLに対応するルーティングは存在しません。

投稿2020/05/13 03:35

maisumakun

総合スコア145208

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

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

987654321

2020/05/13 04:18

解答ありがとうございます。 重ねての質問で申し訳ないのですが、 rails routesで blog_api_blogcomments GET /blogs/:blog_id/api/blogcomments(.:format) api/blogcomments#index {:format=>"json"} と出てきたので、ajaxの部分のurlに url: "api/blogcomments",としたのですが、書き方などが間違っているのでしょうか?
maisumakun

2020/05/13 08:30 編集

> ajaxの部分のurlに url: "api/blogcomments",としたのですが、書き方などが間違っているのでしょうか? そもそも論として、相対パスを使うべきではありません。Railsのような動的なサイトに相対パスを使うと、「今いるページの階層」と「アクセス先のURL」の両方を考える必要が出てきて煩雑になります。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだベストアンサーが選ばれていません

会員登録して回答してみよう

アカウントをお持ちの方は

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

ただいまの回答率
85.46%

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

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

質問する

関連した質問