我有一个功能化的嵌套形式的红宝石色茧。问题是我正在尝试使用插入前和插入后,但是它什么也没做。
我的想法:
<div class="row" id="street_enter_itineraries">
<table>
<div class="street_enter_itineraries" >
<%= f.fields_for :street_enter_itineraries do |builder| %>
<%= render 'street_enter_itinerary_fields', f:builder %>
<% end %>
</div>
</table>
<div class="row">
<%= link_to_add_association "Añadir calle de entrada",f, :street_enter_itineraries, class: 'btn btn-info', data: {association_insertion_node: '.street_enter_itineraries', association_insertion_method: :append} %>
</div>
</div>
我的JavaScript
$(document).ready(function() {
$('#street_enter_itineraries')
.on('cocoon:before-insert', function() {
var allIds= document.getElementsByClassName("tipocalleentradaidentificar");
if(allIds.length > 3){
event.preventDefault();
}
})
.on('cocoon:after-insert', function() {
refreshID();
})
});
我看过这篇文章:Cocoon add association, how to limit number of associations,因为这是我想要做的。我也尝试过此选项,并且控制台为空:
$(document).on('cocoon:after-insert', '.content form', function(e) {
console.log('Something');
});
谢谢。
答案 0 :(得分:0)
您的jquery选择器错误,您一开始忘记了#
来表示正在搜索ID。所以你写了$('street_enter_itineraries')
,你应该写
$('#street_enter_itineraries')
[EDIT]使得js涡轮链接相对容易,要么确保它在turbolinks:load
时被触发,而不是使用document ready事件(在您的情况下可能是最简单的)
$(document).on('turbolinks:load', function(e) {
$('#street_enter_itineraries') ...
})
或使用正确的选择器在文档上注册茧处理程序:
$(document).on('cocoon:before-insert', '#street_enter_itineraties', function(e) {
// do something here
}