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

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

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

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

Ruby on Rails 6

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

Q&A

0回答

1357閲覧

Rails ヘッダーをクリックするたびにURLが追加されてしまいます。

muraishi

総合スコア17

Ruby

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

Ruby on Rails 6

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

0グッド

0クリップ

投稿2020/03/19 17:58

ブログを作っています。

ヘッダーにカテゴリーを設けて、クリックするとそのカテゴリーに紐づいている記事を一覧表示させる機能を作りました。

イメージ説明

ここまでは良いのですが、この状態からヘッダーのカテゴリーをもう一度クリックすると

イメージ説明

このようにURLが http://localhost:3000/categories/categories/6 というふうになってしまいます。

http://localhost:3000/categories/6 というふうにしたいです。

お恥ずかしながら、ググり方もよくわかりませんでした。
よろしくお願いいたします。

routes

1Rails.application.routes.draw do 2 3 root to: "tweets#index" 4 resources :tweets do 5 resources :comments 6 end 7 8 resources :categories 9end 10

controller

1class TweetsController < ApplicationController 2 before_action :set_tweet, only: [:show, :edit, :update, :destroy] 3 4 def index 5 @tweets = Tweet.all.page(params[:page]).per(6).order(id: "DESC") 6 @categories = Category.all 7 end 8 9 def show 10 @tweets = Tweet.all.page(params[:page]).per(6).order(id: "DESC") 11 @categories = Category.all 12 end 13 14 def new 15 @tweet = Tweet.new 16 @categories = Category.all 17 end 18 19 def edit 20 @categories = Category.all 21 end 22 23 def create 24 @tweet = Tweet.new(tweet_params) 25 26 respond_to do |format| 27 if @tweet.save 28 format.html { redirect_to @tweet, notice: 'Tweet was successfully created.' } 29 format.json { render :show, status: :created, location: @tweet } 30 else 31 format.html { render :new } 32 format.json { render json: @tweet.errors, status: :unprocessable_entity } 33 end 34 end 35 end 36 37 def update 38 respond_to do |format| 39 if @tweet.update(tweet_params) 40 format.html { redirect_to @tweet, notice: 'Tweet was successfully updated.' } 41 format.json { render :show, status: :ok, location: @tweet } 42 else 43 format.html { render :edit } 44 format.json { render json: @tweet.errors, status: :unprocessable_entity } 45 end 46 end 47 end 48 49 def destroy 50 @tweet.destroy 51 respond_to do |format| 52 format.html { redirect_to tweets_url, notice: 'Tweet was successfully destroyed.' } 53 format.json { head :no_content } 54 end 55 end 56 57 private 58 def set_tweet 59 @tweet = Tweet.find(params[:id]) 60 end 61 62 def tweet_params 63 params.require(:tweet).permit(:title, :content, :image, category_ids: []) 64 end 65end 66

controller

1class CategoriesController < ApplicationController 2 def show 3 @tweets = Category.find(params[:id]) 4 @categories = Category.all 5 end 6end 7

view

1<div class="navbar1 navbar-light"> 2 〜記事一覧〜 3</div> 4 5<div class="album py-5 bg-light"> 6 <div class="container"> 7 <div class="row"> 8 <% @tweets.tweets.each do |tweet| %> 9 <div class="col-md-4"> 10 <%= link_to tweet do %> 11 <div class="card mb-4 box-shadow"> 12 <div class="card-body"> 13 <% if tweet.image? %> 14 <%= image_tag tweet.image.url, class: "content-image" %> 15 <% else %> 16 <%= image_tag 'klimt.jpg', class: "content-image" %> 17 <% end %> 18 <div class="content-title"> 19 <b><%= tweet.title %></b> 20 </div> 21 <%# <div class="d-flex justify-content-between align-items-center"> 22 <small class="text-muted">9 mins</small> 23 </div> %> 24 </div> 25 </div> 26 <% end %> 27 </div> 28 <% end %> 29 </div> 30 <%# <%= paginate @tweets %> 31 </div> 32</div>

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

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

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

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

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

guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだ回答がついていません

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

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

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問