Rails version: 5.0.2
Ruby version: 2.3.3 (x64-mingw32)
モーダルフォームを表示したいです。
下記を参考にしましたが表示出来ませんでした。
Rails5と BootstrapでAjax-modalform
scaffoldで作成したシンプルなアプリです。
name列しかないuserモデルです。
indexページにあるNew Userボタンを押すと、通常はnewページに遷移しますが、
ここでモーダルを表示させたいといった感じです。
views/users/_form.html.erb
ruby
1<div class="modal-dialog"> 2 <div class="modal-content"> 3 4 5 <%= form_for(@user, remote: true) do |f| %> 6 <% if user.errors.any? %> 7 <div id="error_explanation"> 8 <h2><%= pluralize(user.errors.count, "error") %> prohibited this user from being saved:</h2> 9 10 <ul> 11 <% user.errors.full_messages.each do |message| %> 12 <li><%= message %></li> 13 <% end %> 14 </ul> 15 </div> 16 <% end %> 17 18 19 <div class="field"> 20 <%= f.label :name %> 21 <%= f.text_field :name %> 22 </div> 23 24 <div class="actions"> 25 <%= f.submit %> 26 </div> 27 <% end %> 28 29 </div> 30</div> 31
views/users/new.js.erb
jquery
1$("#user-modal").html("<%= escape_javascript(render 'form') %>") 2$("#user-modal").modal("show")
views/users/index.html.erb
ruby
1<p id="notice"><%= notice %></p> 2 3<h1>Users</h1> 4 5<table> 6 <thead> 7 <tr> 8 <th>Name</th> 9 <th colspan="3"></th> 10 </tr> 11 </thead> 12 13 <tbody> 14 <% @users.each do |user| %> 15 <tr> 16 <td><%= user.name %></td> 17 <td><%= link_to 'Show', user %></td> 18 <td><%= link_to 'Edit', edit_user_path(user) %></td> 19 <td><%= link_to 'Destroy', user, method: :delete, data: { confirm: 'Are you sure?' } %></td> 20 </tr> 21 <% end %> 22 </tbody> 23</table> 24 25<br> 26 27<%= link_to 'New User', new_user_path, remote: true, class: "btn btn-lg btn-primary" %> 28 29 30<div id="user-modal" class="modal fade" tabindex="-1" role="dialog" aria-hidden="true"></div>
controllers/users_controller.rb
ruby
1class UsersController < ApplicationController 2 before_action :set_user, only: [:show, :edit, :update, :destroy] 3 4 # GET /users 5 # GET /users.json 6 def index 7 @users = User.all 8 end 9 10 # GET /users/1 11 # GET /users/1.json 12 def show 13 end 14 15 # GET /users/new 16 def new 17 @user = User.new 18 end 19 20 # GET /users/1/edit 21 def edit 22 end 23 24 # POST /users 25 # POST /users.json 26 def create 27 @user = User.new(user_params) 28 29 respond_to do |format| 30 if @user.save 31 format.html { redirect_to @user, notice: 'User was successfully created.' } 32 format.json { render :show, status: :created, location: @user } 33 format.js { @status = "success"} 34 else 35 format.html { render :new } 36 format.json { render json: @user.errors, status: :unprocessable_entity } 37 format.js { @status = "fail" } 38 end 39 end 40 end 41 42 # PATCH/PUT /users/1 43 # PATCH/PUT /users/1.json 44 def update 45 respond_to do |format| 46 if @user.update(user_params) 47 format.html { redirect_to @user, notice: 'User was successfully updated.' } 48 format.json { render :show, status: :ok, location: @user } 49 else 50 format.html { render :edit } 51 format.json { render json: @user.errors, status: :unprocessable_entity } 52 end 53 end 54 end 55 56 # DELETE /users/1 57 # DELETE /users/1.json 58 def destroy 59 @user.destroy 60 respond_to do |format| 61 format.html { redirect_to users_url, notice: 'User was successfully destroyed.' } 62 format.json { head :no_content } 63 end 64 end 65 66 private 67 # Use callbacks to share common setup or constraints between actions. 68 def set_user 69 @user = User.find(params[:id]) 70 end 71 72 # Never trust parameters from the scary internet, only allow the white list through. 73 def user_params 74 params.require(:user).permit(:name) 75 end 76end 77
現在、New Userをクリックしても何も反応しません。
index.html.erbの、
下から2行目
<%= link_to 'New User', new_user_path, remote: true, class: "btn btn-lg btn-primary" %>
の
remote: trueを消すとモーダルフォームが表示されますが、
newアクションに飛んでしまいます。
見本のまま入力したつもりですが、どこかミスしているようです。
どこが悪いのでしょうか?
宜しくお願い致します。
回答1件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
2017/03/28 22:46
2017/03/29 00:22 編集
2017/03/29 01:50