ruby-on-rails - 如何将 javascript 变量从 Rails 视图传递到操作
问题描述
在我为我的操作创建的视图中,我有一个包含一些 Javascript 代码的用户电子邮件列表。视图采用haml 格式。我想按表单上的提交按钮并在同一操作或其他操作中访问此电子邮件列表。
我尝试过使用 form_tag、form_for 和普通的 html 表单,但是我一直遇到不同的问题。我还测试了 link_to 和 button_to 标签。
以下是我们为 Action 准备的内容:
module RailsAdmin
module Config
module Actions
class BulkProperties < RailsAdmin::Config::Actions::Base
RailsAdmin::Config::Actions.register(self)
register_instance_option :collection do
true
end
register_instance_option :http_methods do
[:get, :put]
end
register_instance_option :controller do
proc do
@all_users = User.all
@all_properties = UserProperty.all
@all_roles = Role.all
binding.pry
if request.get? # EDIT
respond_to do |format|
format.html { render @action.template_name }
format.js { render @action.template_name, layout: false }
end
elsif request.put? # UPDATE
binding.pry #Just testing this
end
end
register_instance_option :link_icon do
'icon-lock'
end
end
end
end
end
这就是我的观点给我带来的问题:
%form
.multiselect-form
.wrapper{"data-children-count" => "1"}
%select.collection{:multiple => "multiple", :id => "multi"}
%hr/
%h1 List of user properties
-@all_properties.each do |prop|
%input{:name => prop.name+"checkbox", :type => "checkbox", :id => prop.name+"checkbox"}
#{prop.name}
%input{:name => prop.name, :type => "text", :id => prop.name}
%br
%input{:name => "submit", :type => "submit", :formaction => 'http://localhost:3000/admin/user/bulk_properties?Application=8&Company=1&locale=en', :method => 'put'}
%br/
%br/
结果是我被引导到一个 CanCan 问题,我得到“你没有被授权......”。这是因为 url 实际上最终保存了参数,因此它试图将我重定向到一个不存在的网页。
解决方案
我实现了一个将带有 js 的文件上传到 S3 并使用 javascript 设置表单字段的值的操作,然后我在 rails 管理操作上使用该 url。
我将其全部粘贴,因为在过去,通过将我的方法与工作方法进行比较,这会在这些情况下对我有所帮助。
以下是相关(简化)文件:
# app/views/rails_admin/main/update_orders_and_line_items.html.haml
= form_tag(method: :post) do
= hidden_field_tag 'uploaded-file-url', '', id: 'uploaded-file-url'
= submit_tag 'Submit', class: 'action-button-pink'
# app/assets/javascripts/google_cloud_storage_field.js
let url = get_url(fileInput);
let valueField = $('#uploaded-file-url');
valueField.val(url);
# lib/rails_admin/config/actions/update_orders_and_line_items.rb
module RailsAdmin
module Config
module Actions
class UpdateOrdersAndLineItems < RailsAdmin::Config::Actions::Base
# Might cause random bugs if enabled
register_instance_option :pjax? do
false
end
register_instance_option :http_methods do
[:post, :get]
end
register_instance_option :controller do
proc do
if request.post?
url = params['uploaded-file-url']
do_stuff_with(url)
elsif request.get?
# [...]
end
end
end
end
end
end
end
我相信您的错误的来源是使用%form
标签,表单的默认方法是 GET,这就是为什么您的浏览器尝试将您重定向到某个页面的原因,如果您像我一样使用form_tag(method: :post)
并确保电子邮件位于 hidden_field_tag 值上,您将在 action.rb 中获得您的列表
推荐阅读
- python - Python加载txt文件并按行中的位置拆分行
- time-series - 基于非等距时间序列输入的 RNN 预测
- azure - 在 Azure 文件服务 REST Api 上调用创建文件
- swift - 带有 Swift 的 Google 课堂 API
- c# - 当某些人有某些自定义字段时,避免在高级搜索中使用多个参数?
- visual-studio-code - VSCode - 自定义 scss 文件中元素、ID 和类文本的颜色?
- javascript - 为 new Date().toLocaleString() 设置日期格式
- javascript - 重新排列 json 文件
- matlab - 振动分析科学实验室
- c# - 当我点击逃生时,暂停菜单不会激活