2012-10-16 6 views
0
를 사용하는 경우 대신 파셜의 페이지를 새로 고침

가능한 중복 :
Rails - AJAX to for new/create action레일 - AJAX

나는 그것에 이벤트에 대한 부분 지문이있는 타임 라인을 직접에 할 수 있습니다 CRUD 이벤트 때문에 타임 라인. 이벤트가 삭제 될 때마다 부분 삭제 및 타임 라인 새로 고침을 할 수 있도록 삭제 부분이 올바르게 작동합니다. 그러나 새로운 이벤트가 만들어지면 작동시키지 못합니다. 양식과 타임 라인을 새로 고치는 대신 전체 페이지가 새로 고침됩니다.

컨트롤러와 관련 있다고 가정합니다. 그러나 나는 그것을 고칠 수 없다. 0)

이벤트 컨트롤러 :

def create 
    @event = Event.new(params[:event]) 

    respond_to do |format| 
     if @event.save 
     format.html { redirect_to @event.timeline, notice: 'Event was successfully created.' } 
     format.json { render json: @event, status: :created, location: @event } 
     format.js 
     else 
     format.html { render action: "new" } 
     format.json { render json: @event.errors, status: :unprocessable_entity } 
     format.js 
     end 
    end 
    end 

타임 라인/쇼 :

<div id="new-event"> 
     <%= render :partial => "new_event", :locals => { :event => Event.new(:timeline_id=>@timeline.id) }, :remote => true %> 
    </div> 

타임 라인/_new_event :

<br /> 
<h2>Add an event</h2> 
<h4>Fill in the form and click 'Create Event' to add a new event to the timeline.</h4> 

<%= form_for(event) do |f| %> 
    <% if event.errors.any? %> 
    <div id="error_explanation"> 
     <h2><%= pluralize(event.errors.count, "error") %> prohibited this event from being saved:</h2> 

     <ul> 
     <% event.errors.full_messages.each do |msg| %> 
     <li><%= msg %></li> 
     <% end %> 
     </ul> 
    </div> 
    <% end %> 

    <%=f.hidden_field 'timeline_id', :value => current_user.timeline.id %> 
    <div class="field"> 
    <%= f.label :date %><br /> 
    <%= f.date_select :start_date, :order => [:day, :month, :year], :start_year => 1800 %> 
    </div> 
    <div class="field"> 
    <%= f.label :title %><br /> 
    <%= f.text_field :headline, :size => 50 %> 
    </div> 
    <div class="field"> 
    <%= f.label :event_description %><br /> 
    <%= f.text_area :text, :size => "47x4" %> 
    </div> 
    <%= check_box_tag "blockCheck", :value => "1", :checked => false %> 
    <div class="field" id="media_box"> 
    <%= f.label :media %>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;<span>Please paste a URL here</span><br /> 
    <%= f.text_field :media, :size => 50 %> 
    </div> 
    <div class="field"> 
    <%= f.label :media_description %><br /> 
    <%= f.text_area :caption, :size => "47x3" %> 
    </div> 
    <div class="actions"> 
    <%= f.submit 'Create Event', :class => "btn btn-success", :remote => true %> 
    </div> 
<% end %> 

이벤트 생성/어떤 도움을 많이 감사 감사하겠습니다 .jrser :

$('#new-event').html('<%= escape_javascript(render :partial => "/timelines/new_event", :locals => { :event => Event.new(:timeline_id=>@timeline.id) }) %>'); 
$('.notice').html("<p>Event was successfully created.</p>"); 
$('.notice').show(300); 
$('#my-timeline-box').html('<%= escape_javascript(render :partial => "/timelines/my_timeline") %>'); 
$('#show-timeline').html('<%= escape_javascript(render :partial => "/timelines/show_timeline") %>'); 

(하단 두 줄은 타임 라인 자체를 새로 고칩니다.)

UPDATE : 당신은 제출 버튼을 :remote => true

Started POST "/events" for 127.0.0.1 at 2012-10-16 14:52:37 +0100 
Processing by EventsController#create as JS 
    Parameters: {"utf8"=>"V", "authenticity_token"=>"i8oiRI7rOLsfb5o45QCK0te/hAsWv 
BMTqpxU9KrbmNA=", "event"=>{"timeline_id"=>"1", "start_date(3i)"=>"16", "start_d 
ate(2i)"=>"10", "start_date(1i)"=>"2012", "headline"=>"", "text"=>"", "media"=>" 
", "caption"=>""}, "commit"=>"Create Event"} 
    ←[1m←[35m (0.0ms)←[0m begin transaction 
    ←[1m←[36mSQL (5.0ms)←[0m ←[1mINSERT INTO "events" ("caption", "created_at", " 
credit", "end_date", "headline", "media", "start_date", "text", "thumbnail", "ti 
meline_id", "updated_at") VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?)←[0m [["capti 
on", ""], ["created_at", Tue, 16 Oct 2012 13:52:37 UTC +00:00], ["credit", nil], 
["end_date", nil], ["headline", ""], ["media", ""], ["start_date", Tue, 16 Oct 
2012], ["text", ""], ["thumbnail", nil], ["timeline_id", 1], ["updated_at", Tue, 
16 Oct 2012 13:52:37 UTC +00:00]] 
    ←[1m←[35m (88.0ms)←[0m commit transaction 
    Rendered events/create.js.erb (99.0ms) 
Completed 500 Internal Server Error in 617ms 

ActionView::Template::Error (Called id for nil, which would mistakenly be 4 -- i 
f you really wanted the id of nil, use object_id): 
    1: $('#new-event').html('<%= escape_javascript(render :partial => "/timelin 
es/new_event", :locals => { :event => Event.new(:timeline_id=>@timeline.id) }) 
%>'); 
    2: $('.notice').html("<p>Event was successfully created.</p>"); 
    3: $('.notice').show(300); 
    4: $('#my-timeline-box').html('<%= escape_javascript(render :partial => "/t 
imelines/my_timeline") %>'); 
    app/views/events/create.js.erb:1:in `_app_views_events_create_js_erb___8626901 
43_20024148' 
    app/controllers/events_controller.rb:59:in `create' 


    Rendered C:/Ruby193/lib/ruby/gems/1.9.1/gems/actionpack-3.2.4.rc1/lib/action_d 
ispatch/middleware/templates/rescues/_trace.erb (5.0ms) 
    Rendered C:/Ruby193/lib/ruby/gems/1.9.1/gems/actionpack-3.2.4.rc1/lib/action_d 
ispatch/middleware/templates/rescues/_request_and_response.erb (2.0ms) 
    Rendered C:/Ruby193/lib/ruby/gems/1.9.1/gems/actionpack-3.2.4.rc1/lib/action_d 
ispatch/middleware/templates/rescues/template_error.erb within rescues/layout (1 
000.1ms) 

답변

1

: 여기

는 오류 메시지입니다. 그건 잘못된거야. 다음 형식이어야합니다 :

<%= form_for(event, :remote => true) do |f| %> 
+0

. 질문을 쉽게 읽을 수 있도록 붙여 넣었습니다. 이드는 왜 지나치지 않습니까? 감사. – ecs

+0

create.js.erb는'@timeeline'을 기대하지만, 컨트롤러의'create' 메소드에서'@ timeline'을 정의하지 않았습니다. – Mischa

+0

잘 됐네요, 지금 일하고 있어요, 도와 줘서 고마워요. – ecs

1

컨트롤러 코드에 @timeline을 초기화하지 않았습니다. 따라서 당신은 무의미한 행동을 취합니다.

그래서, 당신의 생성 코드에 넣어 :

지금 새로 고침에서 페이지를 중지하지만 지금 로그에 오류를 얻고있다
@timeline = current_user.timeline 
+0

과 후손을 위해 : 그 수동 ID로 조종하는 대신 timeline.events.new를 사용하는 것이 어떻습니까? –

+0

팁을 주셔서 감사합니다. – ecs

관련 문제