ruby-on-rails - 非法嵌套 : nesting within plain text is illegal

标签 ruby-on-rails haml

我是 HAML 的新手,我有一个错误:Illegal nesting: nesting within plain text is illegal. .目前,我正在尝试将我的 erb 更改为 haml,但它不起作用。这是我的 erb。

<script src="https://js.braintreegateway.com/v2/braintree.js"></script>
<h2 class="mbs">New Subscription
</h2>
<%= simple_form_for :subscription, :url => subscribe_subscription_path(@plan.id), :id => "checkout-form" do |f| %>
  <% if current_user and !current_user.has_payment_info? %>
    <%= render 'customer_form'%>
  <% end %>
  <br/>
  <p> Please enter payment details: </p>
  <div id="payment-form"></div>
  <div id="coinbase-container-id"></div>
  <div class="form-actions">
    <%= f.submit t(:subscribe), :class => 'btn btn-primary' %>
  </div>
  <script charset="utf-8" type="text/javascript">
    var clientToken = "<%= @client_token %>";
    braintree.setup(clientToken, "dropin", {
      container: "payment-form",
      coinbase: { container: "coinbase-container-id" }
      });
  </script>
<% end %>

我的 HAML 是:
%script{:src => "https://js.braintreegateway.com/v2/braintree.js"}
%h2.mbs
New Subscription
= simple_form_for :subscription, :url => subscribe_subscription_path(@plan.id), :id => "checkout-form" do |f|
  - if current_user and !current_user.has_payment_info?
    = render 'customer_form'
  %br/
  %p Please enter payment details:
  #payment-form
  #coinbase-container-id
  .form-actions
    = f.submit t(:subscribe), :class => 'btn btn-primary'
  %script{:charset => "utf-8", :type => "text/javascript"}
    var clientToken = "#{@client_token}";
    braintree.setup(clientToken, "dropin", {
      container: "payment-form",
      coinbase: { container: "coinbase-container-id" }
    });

怎么了?为什么会显示这个错误?

最佳答案

问题出在您的 script标签:

%script{:charset => "utf-8", :type => "text/javascript"}
  var clientToken = "#{@client_token}";
  braintree.setup(clientToken, "dropin", {
    container: "payment-form",
    coinbase: { container: "coinbase-container-id" }
  });

线路container: "payment-form",比前一行缩进更多,Haml 试图将它解析为一个块或一个标签的内容,但前一行是纯文本并且没有任何一个。

要修复它,您可以使用 :javascript filter它允许在其下方混合缩进:
:javascript
  var clientToken = "#{@client_token}";
  braintree.setup(clientToken, "dropin", {
    container: "payment-form",
    coinbase: { container: "coinbase-container-id" }
  });
:javascript过滤器还添加了 <script>标签。如果你有理由控制这个标签的属性,你可以使用 :plain filter使用您自己的标语:
%script{:data => {:example => "Foo"}}
  :plain
    var clientToken = "#{@client_token}";
    braintree.setup(clientToken, "dropin", {
      container: "payment-form",
      coinbase: { container: "coinbase-container-id" }
    });

关于ruby-on-rails - 非法嵌套 : nesting within plain text is illegal,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/32813968/

相关文章:

html - 我可以在两个箭头之间放置一个 Rails 部分吗?

ruby-on-rails - HAML - 如何创建表单验证并显示错误消息?

ruby-on-rails - 如何将 best-in-place 与 bootstrap-datepicker 集成

haml - HAML,将类添加到image_tag

ruby - 使用 Haml 将生成的文本插入到与文字内容相同的行中

ruby-on-rails - Rails fields_for :child_index option explanation

forms - 轨道 4 : Set default field in form partial only if new form

sql - MySQL 不使用带有 WHERE IN 子句的索引?

ruby-on-rails - 如何在带有 bundler 的项目中使用 rails 分支中的分支

javascript - 谷歌地图信息窗口打不开