- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
在 Ruby on Rails 应用程序中,假设我有一个 Item 和一个 Order 模型,如下所示:
class Item
:name
:default_price
end
class Order
:customer
:item_id
:order_price
end
在订单表单上,我可以使用 javascript 和 json 调用自动使用 default_price 填充 order_price 字段,如下所示:
$(function (){
$('#order_item_id').live("change", function(e) {
e.preventDefault();
$.ajax({
url: "/items/" + $(this).val(),
dataType: "json",
contentType: "application/json; charset=utf-8",
success: function(data) {
$('#order_price').val(data.item.default_price);
},
error: function(xhr,exception,status) {
//errors....
}
});
});
});
到目前为止,还不错。但现在假设我希望能够在一个订单下列出多个项目。在这种情况下,我可以使用嵌套形式和下表:
class Item
:name
:default_price
end
class Order
:customer
end
class OrderItem
:order_id
:item_id
:order_price
end
问题是每个嵌套的 OrderItem 记录都有相同的选择 ID 和一个随机的 order_price ID,例如:
<div class="fields">
<ol>
<li> //first nested record
<select id="order_item_id"></select>
<input id="order_orderitems_attributes_0_orderprice"></input>
</li>
<li> //second nested record
<select id="order_item_id"></select>
<input id="order_orderitems_attributes_###randomnumber###_orderprice"></input>
</li>
</ol>
</div>
显然这会导致 javascript 函数出现问题。
如何让我的嵌套表单与我的 javascript 完美配合,以便选择一个项目填充相应的价格字段?
我需要将嵌套记录的标识符传递给函数,以便函数在选择字段更改时运行。我还需要以某种方式识别正确的订单价格字段。
有人有什么想法吗?
谢谢!!!
编辑
实际上,我可以通过使用 .next() 选择器查找下一个 DOM 元素来实现这一点。即,在 js 函数中
$('#order_item_id').live("change", function(e) {
var current_price = $(this).next('.order-price')[0];
.....
success: function(data) {
$('current_price').val(data.item.default_price);
},
.....
但我对每个选择字段都具有相同的 ID 感到不自在。这是我应该关心的事情吗?有什么我应该考虑的问题吗?
编辑 2
订单
<%= nested_form_for @order do |f| %>
.....order fields
<ol>
<%= f.fields_for :orderitems %>
</ol>
<p><%= f.link_to_add new_ico, :orderitems %></p>
<p><%= f.submit %></p>
<% end %>
部分订单项
<li>
<%= select(:orderitem,:item_id,@items.collect{|s|[s.name, s.id]},:prompt=>"select") %>
<%= f.text_field :order_price, :class => "order-price" %>
</li>
最佳答案
所以您想要更改所选项目以在 select
之后立即更新输入,对吧?如果是这样,您可以将 success
处理程序更改为如下所示:
function(data) {
// this refers to the select that its value has changed
// and next('input') finds the input right after it
$(this).next('input').val(data.item.default_price);
}
为了使输入包含特定值(例如订单价格)更加明确,您可以为其分配一个 HTML 5 data-
属性,如下所示:
<%= f.input :order_price, :"data-field" => "order-price" %>
这样 JavaScript 中的 CSS 选择器会变得更加直观:
function(data) {
// this refers to the select that its value has changed
// and next('input') finds the input right after it
$(this).next('input[data-field=order-price]').val(data.item.default_price);
}
值得一提的是,如果您使用的是最新版本的 jQuery,data-
属性甚至可以在 HTML 4 中使用。
关于javascript - ruby rails : How to identify nested_form elements in javascript functions?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/9051727/
我在 Rails 3.1 应用程序中使用 gemnested_form。问题是,当我点击“link_to_add”生成的链接时,它会显示两次,而它应该只显示一次。你有一些代码: 形式: {:mult
我有一个嵌套表单(按订单付款),我想在编辑 View 中测试嵌套表单 (fields_for) 中的值。但问题是我无法检查每一个,我可以这样做: 您现在是否可以检查每个,例如: 最佳答案 如果我理
我正在使用来自 GitHub 的 Ryan Bates 的nested_form gem 的 madebydna 版本(可以在 https://github.com/madebydna/nested_
我目前有一个具有深度嵌套的复杂表单,并且我正在使用 Cocoon gem 根据需要动态添加部分(例如,如果用户想要在销售表单中添加另一辆车)。代码如下所示: "sale_vehicles/
我在 _form.html.haml 部分中有以下代码,它用于新建和编辑操作。(仅供引用,我使用 Ryan Bates 的插件 nested_form ) .fields - f.fields
我的模型中有以下代码: Class Farm :destroy has_many :products, :through => :farm_products accepts_nested_a
我正在使用 Ryan Bates nested_form_for:https://github.com/ryanb/nested_form .对于我的 select 语句,我使用的是 chosen-s
我正在使用嵌套表单 gem,其中有两个字段, View 给出为
更新:根据在此问题末尾发布的堆栈跟踪,我认为真正的问题是弄清楚我需要什么 attr_accessible 和构建关联设置来获取贡献者和链接器属性以使用新的 isbn id 进行更新。请帮我! 继 th
我的 new.html.erb 工作正常。 但是在我的 edit.html.erb 中,假设我有 3 个现有部门... 每当我单击“添加部门”链接(以添加另一个字段)时,它都会继续位于现有部门上方,而
我正在研究如何为嵌套模型动态添加表单字段,并偶然发现了 nested_form ryanb 的插件。毫无疑问,这是一段很棒的代码,但我想知道为什么它必须如此复杂? 示例:用于创建/添加项目的表单分配了
在 Ruby on Rails 应用程序中,假设我有一个 Item 和一个 Order 模型,如下所示: class Item :name :default_price end class O
我有一个嵌套形式并使用 ryan bates 的 nested_form gem,其中我在该领域使用 raty stars,形式给出为 'btn
Update: answered here . 这里和互联网上有很多关于让nested_form、collection_select、accepts_nested_attributes_for 和fi
我通常不为表单使用表格,但是当有嵌套表单时(当使用 nested_form 或 cocoon gem 时),是否可以将每组表单元素放在表格行中? 对我来说,这似乎很直观:表格中的每一行都代表一个对象。
我的问题有点类似于问题 nested_form gem add works but remove fails...why? . 我有一个产品编辑页面,其中产品的子类别链接在 product_sub_c
更新:在进行了一些挖掘并意识到这可能是导致问题的 twitter-bootstrap 之后,我更新了它。 这是我的嵌套表单的粗略版本: { :class => 'form-horizontal' }
我已经为这个问题苦苦挣扎了好几天,而且似乎无法弄清楚出了什么问题。我正在尝试允许模型Item属于模型Location的多态文件附件。我的路线定义为: resources :locations do
我对 gem nested_form 有点问题。我有: class Factura :itemfacturas accepts_nested_attributes_for :itemfactura
我正在使用 simple_form、nested_form 和 Twitter Bootstrap,并尝试将 nested_form 中的“删除链接”与对象放在同一行。 现在它看起来像这样: http
我是一名优秀的程序员,十分优秀!