我已将FriendlyId gem(版本4.0.8)与Rails应用程序一起使用。我已按照RailsCasts上的教程进行操作,根据文档,我必须在rails控制台上运行Model.find_each(&:save)
以生成旧记录的slugs。但是,当我这样做时,我的所有旧记录的slug属性仍然没有,所以它并没有真正改变网址。
我做错了吗?这只发生在生产方式上。它在开发上运行良好。
更新
我的模型看起来像这样:
class Member < ActiveRecord::Base
extend FriendlyId
friendly_id :name, use: :slugged
belongs_to :gym
attr_accessible :category, :name, :description
validates :category, :name, :description, :presence => true
has_attached_file :avatar, :styles => { :medium => "300x300>", :thumb => "100x100>" }
def self.search(search)
if search.present?
where("name LIKE ?", "%#{search}%")
else
find(:all)
end
end
def should_generate_new_friendly_id?
new_record?
end
end
答案 0 :(得分:9)
should_generate_new_friendly_id?
返回false,因为new_record?
为false,因为您的记录已经存在。
删除should_generate_new_friendly_id?
方法,或试试此&amp;重新运行:
def should_generate_new_friendly_id?
new_record? || slug.blank?
end
答案 1 :(得分:2)
我在开发 Rails 6 应用程序时遇到了同样的挑战。
我是这样解决的:
默认情况下,Friendly_id gem 不会为 Rails 应用程序中的现有记录生成 slug。因此,如果您有模型的现有记录,则不会为它们生成 slug。它们只会为较新的记录生成。
要为现有记录生成 slug,请执行以下操作。假设我们的模型名称是 Blog
,我们要用于 slug 的列是 title
,我们将执行以下操作:
请务必先向 Blog
表中添加一个 slug 列:
rails g migration AddSlugToBlogs slug:uniq
接下来,生成友好的配置文件和新的迁移(如果您还没有这样做):
rails generate friendly_id
接下来,运行您的数据库迁移:
rails db:migrate
接下来,编辑 app/models/blog.rb
文件如下:
class Blog < ApplicationRecord
extend FriendlyId
friendly_id :title, use: :slugged
end
接下来,编辑 app/controllers/blogs_controller.rb
文件并将 Blog.find 替换为 Blog.friendly.find
class BlogController < ApplicationController
def show
@blog = Blog.friendly.find(params[:id])
end
end
或
class BlogsController < ApplicationController
before_action :set_blog, only: %i[ show edit update destroy ]
def show
end
private
# Use callbacks to share common setup or constraints between actions.
def set_blog
@blog = Blog.friendly.find(params[:id])
end
end
最后,启动 Rails 控制台并运行以下命令为现有记录生成 slug:
rails console
Blog.find_each(&:save)
注意:您必须在拥有现有记录的所有环境(例如测试、暂存和生产)中运行此命令,以便为这些环境中的记录生成 slug。< /p>
现在,当您创建一个如下所示的新博客时,请说出标题 - 我的第一个博客, 您将能够使用 URL http://localhost:3000/blogs/my-first-blog 访问博客展示页面。
仅此而已。
我希望这会有所帮助