我有一个具有描述,数量和单位成本的表格(简单表格)。
我使用JS显示每一行的小计和总计,只为用户可以看到总计。
我的问题是我想将表单总计保存在同一个表单中的输入中,也许这不是最好的方法,但是我需要这样做。
输入“总计”与其他输入的结果数(q1 * v1)+(q2 * v2)一起保存,我不需要实时显示,只是在创建表单时保存它< / p>
<%= f.input :v1%> <!-- value of item 1 -->
<%= f.input :q1%> <!-- quantity of item 1 -->
<%= f.input :v2%> <!-- value of item 2 -->
<%= f.input :q2%> <!-- quantity of item 2 -->
<%= f.input :total %> <!-- here i need to automaticle save the
value of (v1*q1)+(v2*q2) when I hit the submit(create) button-->
答案 0 :(得分:1)
这是您可以在JavaScript前端或在Rails后端
(我假设您要在后端执行此操作,因为您说的只是正确地保存 才重要。)
为此,您需要在before_save
回调中将此逻辑放入ActiveRecord模型中(通常,逻辑不应进入Controller)。
# app/controllers/my_models_controller.rb
class MyModelsController < ApplicationController
def update
@model = MyModel.new(my_model_params)
if @model.save
# It worked
else
# It failed
end
end
private
def set_model
#...
end
def my_model_params
params.permit(:v1,v2,q1,q2)
end
end
# app/models/my_model.rb
class MyModel
attr_accessor :v1
attr_accessor :v2
attr_accessor :q1
attr_accessor :q2
before_save :calculate_total
private
def calculate_total
@total = (v1*q1)+(v2*q2)
end
end
这只是伪代码,但我希望它为您提供了如何完成此操作的好方法。测试一下(它需要一些调整)-应该可以。
希望有帮助:)
答案 1 :(得分:0)
@Patrick感谢您给我正确的方法,但是我无法使其正常工作,只保存空白字段,甚至是原始的q1 v1,最后这段代码对我来说还是有用的
before_save do
self.total = (self.q1 * self.v1) * (self.q2 * self.v2)
end