我试图在我的coffeescript代码中应用“刷新”触发器,但我没有找到正确的语法:jquery sortable refresh => coffeescript中正确的语法是什么?
在标准jQuery中,它会是:$('。milestone_chain')。sortable '刷新')
它会在CoffeeScript中是什么,知道这是我的代码:
$('.milestone_chain').sortable
axis: 'y'
containment: 'parent'
cursor: 'move'
tolerance: 'pointer'
update: (event,ui)->
$('li > a > div > span.number').each (i, element) =>
$(element).html i+1
$.ajax($(this).attr('data-update-url') + '/' + ui.item.attr('id') + '/reorder/' + (ui.item.index() + '.js'))
的HTML如下:
<ul class="milestone_chain" data-update-url="projectmilestones">
<% projectcapstone.projectmilestones.rank(:rank).includes(:projectdepartment).each.with_index do |projectmilestone, i| %>
<li class="milestone_<%=projectmilestone.projectdepartment.ranking%>" id="<%=projectmilestone.id%>">
<div class="chainpie"><%= percent_pie(projectmilestone.status)%></div>
<div class="milestone<%=projectmilestone.projectdepartment.ranking%>"><%= link_to content_tag(:span, i+1, :class => "number"), projects_projectmilestone_path(projectmilestone) %></div>
<div class="milestonenum">
<%= link_to projectmilestone.name, projects_projectmilestone_path(projectmilestone) %>
<b class="notch"></b>
</div>
</li>
<% end %>
</ul>
它运作良好。问题在于代码有时需要在Ajax中加载,然后再无法使用。这就是我要实现刷新方法的原因。如果我理解正确,它解决了这个问题
谢谢!
究竟是什么问题?当我将你的代码应用到咖啡编译器时,我得到了我期望的Javascript ......'sortable'下的所有东西都是一个包含指定选项的对象。什么不起作用? –
我的问题是,在Ajax中加载html时,它不起作用。我更新了这篇文章,提供了关于代码的更多信息。 – ndemoreau