我有两个版本的同一索引页面,显示产品列表。常规视图-显示列表管理员视图-显示带有编辑、删除等选项的列表。
索引操作只是进行数据库查询并返回该实例变量。目前,我有相同的索引操作来呈现索引页面。我想将索引操作表单产品重新使用到管理控制器中。
def index
@products = Product.all
end
路线:
/product/index => product#index
/admin/product/index => product#index
我尝试了给定的prepend_view_path技术[here|How can I intercept rails';s模板渲染,但在这两种情况下,这总是最终渲染admin/product/index.html.erb文件。
我想让产品#索引控制器#动作呈现:
/index.html.erb for/product/index
和
/admin/product/index.html.erb for/admin/product/index
有人能帮助我以一种优雅的方式完成这项工作吗?而不仅仅是为管理控制器类和产品控制器类编写相同的操作。
附言:我刚上《红宝石与红宝石在铁轨上》一周。非常感谢您的帮助。
路线中存在错误。
/product/索引=>product#索引
/admin/product/index=>product#index
两者都指向与产品相同的控制器名称。
我建议这些路线
resources :admin do
resources :product do
end
end
resources :product do
end
通过这样做,你可以确保你有两个产品控制器。一个带有管理员::ProductController第二产品控制器
管理员视图的admin_product_path普通视图的product_path
从您的控制器中,只需呈现您想为用户服务的视图,我的意思是:
ProductsController
def index
# ...
render 'index'
end
Admin::ProductsController
def index
# ...
render 'products/index'
end
我在开发Rails 6应用程序时遇到了这个挑战。
我有两种类型的用户:客户和管理员。我使用Devise宝石进行身份验证。我希望客户的产品视图与管理员不同。
我在控制器中已经有一个app/controllers/admins
目录,用于管理员的Devise配置。
以下是我的操作方式:
首先,使用admins
命名空间为Admins products
视图定义一个新的路由。
namespace :admins do
resources :products do
end
end
注意:这将影响管理员的路径/URL。比如说,products_path
将不是admins_products_path
。
然后,在控制器中将products_controller.rb
添加到app/controllers/admins
目录:
class Admins::ProductsController < ApplicationController
before_action :set_product, only: [:show, :edit, :update, :destroy]
# GET /products
# GET /products.json
def index
@products = Product.all
end
# GET /products/1
# GET /products/1.json
def show
end
# GET /products/new
def new
@product = Product.new
end
# GET /products/1/edit
def edit
end
# POST /products
# POST /products.json
def create
@product = Product.new(product_params)
respond_to do |format|
if @product.save
format.html { redirect_to admins_product_path(@product), notice: 'Product was successfully created.' }
format.json { render :show, status: :created, location: admins_product_path(@product) }
else
format.html { render :new }
format.json { render json: @product.errors, status: :unprocessable_entity }
end
end
end
# PATCH/PUT /products/1
# PATCH/PUT /products/1.json
def update
respond_to do |format|
if @product.update(product_params)
format.html { redirect_to admins_product_path(@product), notice: 'Product was successfully updated.' }
format.json { render :show, status: :ok, location: admins_product_path(@product) }
else
format.html { render :edit }
format.json { render json: @product.errors, status: :unprocessable_entity }
end
end
end
# DELETE /products/1
# DELETE /products/1.json
def destroy
@product.destroy
respond_to do |format|
format.html { redirect_to admins_products_url, notice: 'Product was successfully destroyed.' }
format.json { head :no_content }
end
end
private
# Use callbacks to share common setup or constraints between actions.
def set_product
@product = Product.find(params[:id])
end
# Only allow a list of trusted parameters through.
def product_params
params.require(:product).permit(:name, :sku, :short_description, :full_description)
end
end
注意:注意使用管理员模块的产品控制器名称空间以及的create
、update
和destroy
操作中修改的路径
最后,在视图中,添加与app/views/admins/products
目录中的Admins Products关联的视图。
注意:您可能需要修改视图中的路径,以与管理员产品的路由相对应。比方说,管理员产品的show
视图将是admins_product_path(product)
,而不是product
或product_path(product)
。
有一种更清洁的方法使用细胞宝石。这消除了重复代码的需要,当您需要为最多3个或更多角色定义视图时,它会派上用场。您可以在这里阅读更多关于如何使用它的信息:Rails中的面向对象视图。
仅此而已。
我希望这能帮助