0

我正在尝试修改此视图文件:https ://github.com/spree/spree/blob/master/frontend/app/views/spree/checkout/edit.html.erb

我要做的就是在这一行中修改一个十二到十级:

 <div class="columns <%= if @order.state != 'confirm' then 'alpha twelve' else 'alpha omega sixteen' end %>" data-hook="checkout_form_wrapper">

最好的方法是什么?我能想出的唯一解决方案是使用以下污损脚本,但这似乎不是很好的方法:

<!-- replace '[data-hook="checkout_content"]' -->
<div class="row" data-hook="checkout_content">
<div class="columns <%= if @order.state != 'confirm' then 'alpha ten' else 'alpha omega sixteen' end %>" data-hook="checkout_form_wrapper">
  <%= form_for @order, :url => update_checkout_path(@order.state), :html => { :id => "checkout_form_#{@order.state}" } do |form| %>
    <% unless @order.email? %>
      <p class="field" style='clear: both'>
        <%= form.label :email %><br />
        <%= form.text_field :email %>
      </p>
    <% end %>
    <%= render @order.state, :form => form %>
  <% end %>
</div>
<% if @order.state != 'confirm' %>
  <div id="checkout-summary" data-hook="checkout_summary_box" class="columns omega six">
    <%= render :partial => 'summary', :locals => { :order => @order } %>
  </div>
<% end %>

还有其他方法可以实现我的目标吗?谢谢你的回答!

4

1 回答 1

0

您可以尝试使用 deface 的 set attributes 属性来更改该 div 的类的属性。

从污损文档:

:set_attributes - 设置与提供的选择器匹配的所有元素的属性,如果存在则替换现有属性值,如果不存在则添加。期望 :attributes 选项被传递

同样对于稍微不同的解决方案,您可以尝试使用 CSS 选择器来设置宽度:

div.twelve[data-hook="checkout_form_wrapper"] {
  width: something_less_than_what_you_had_before
}
于 2013-06-26T00:44:45.810 回答