【发布时间】:2017-02-13 22:03:19
【问题描述】:
我不知道为什么我的 javascript 没有被执行(而且它真的没有被执行)。
/app/assets/javascripts/application.js:
//= require jquery
//= require bootstrap-sprockets
//= require turbolinks
//= require jquery_ujs
//= require_tree .
/app/controllers/project_controller.rb:
def upload
@projects = Project.all.order(updated_at: :desc)
@project = Project.find(params[:id])
respond_to do |format|
format.html
format.js {render layout: false}
end
end
/app/views/projects/show.html.erb:
<%= link_to project_upload_path, :project => @project.id, class: "btn btn-default" do %>
Upload
<%= glyph("plus") %>
<% end %>
/app/views/projects/upload.html.erb:
<div class="row">
<div class="col-xs-12">
<h2>Upload File to <%= @project.name %> project</h1>
</div>
<br>
<div class="col-xs-12">
<%= render :partial => "uploadform", :action => "savefile" %>
</div>
</div>
/app/views/projects/_uploadform.html.erb:
<%= form_for :upload, url: {action: "savefile"}, :multipart => true do |f| %>
<%= f.hidden_field(:project_id, :value => params[:id]) %>
<%= f.file_field :file, input_html: { hidden: true }, label: 'Upload Attachment' %>
<input id="file-display" class="input-large uneditable-input" type="text">
<%= f.submit "Save File", :class => "btn btn-default btn-file", :id => "upload-btn" %>
<% end %>
/app/views/projects/upload.js.erb:
$(document).on('ajax:success', function() {
alert("Test");
});
我什么都试过了。我在控制器中添加并删除了“{render layout: false}”。我在 upload.js.erb 中尝试了“page:change”和“turbolinks:load”(而不是“ajax:success”)。我在“_uploadform.js.erb”(而不是“upload.js.erb”)中尝试了所有 Java-Ready 函数。我在link_to(show.html.erb)中尝试了“remote:true” - 但它只执行js.erb(只是出现了警报)。我还将 Rails 从 4.2.1 更新到 4.2.7.1,并在 application.js 中尝试了“//= require jquery.turbolinks”(具有上述所有文档就绪功能)。
正如您在我的日志中看到的,它似乎没有用 Javascript 响应:
Started GET "/projects/upload/20" for 127.0.0.1 at 2016-10-05 14:05:48 +0200
Processing by ProjectsController#upload as HTML
Parameters: {"id"=>"20"}
Project Load (0.0ms) SELECT "projects".* FROM "projects" WHERE "projects"."id" = ? LIMIT 1 [["id", 20]]
Rendered projects/_uploadform.html.erb (0.0ms)
Rendered projects/upload.html.erb within layouts/application (2.4ms)
Completed 200 OK in 327ms (Views: 324.8ms | ActiveRecord: 0.0ms)
请帮助我。我不明白为什么这不起作用。
【问题讨论】:
-
我认为没有
ajax:success选择器。你是说$(document).ajaxSuccess -
没有。我不知道我从哪里得到的,但它也不适用于“turbolinks:load”或“page:change”。所以,是的,也许“ajax:success”是错误的,但其他选择器也不起作用。
-
不知道有什么区别,但是尝试在你的
jquery之后加载jquery_ujsapplication.js -
不,遗憾的是这并没有帮助(即使很难,我只是在 jquery_ujs 之后加载了 jquery(因为我认为我已经在 jquery 之后加载了 jquery_ujs))。
标签: javascript ruby-on-rails ruby-on-rails-4 turbolinks unobtrusive-javascript