Haml -Illegal nesting:在纯文本中嵌套是轨道上的非法ruby

时间:2016-10-19 18:05:36

标签: ruby-on-rails haml

我不使用haml很多,因为主要是我总是使用erb,虽然对于这个特殊项目他们希望我使用它。 错误发生在表单之后,我使用制表符而不是空格。知道为什么这不起作用吗?

%div(id="openModal" class="modalDialog")
    %div
        %a(href="#close" title="Close" class="close")
        <form id="car-form" enctype="multipart/form-data" action="/cars" accept-charset="UTF-8" method="post">
            <input name="utf8" type="hidden" value="✓">
            <input type="hidden" name="authenticity_token" value="dNdUmF8Kp5jFgXwtBIV0W6NS8anp28Y7Ts7AOQGqez/BoSzlB1bb+5VXLU148dJClYXdOx/qV6b2QdBOIsEmxQ==">
            <div class="control-group">
                <label for="Year">Year</label>
                <br>
                <input type="text" name="year" id="year" style="background-image: url(&quot;&quot;); background-repeat: no-repeat; background-attachment: scroll; background-size: 16px 18px; background-position: 98% 50%;">
            </div>
            <br>
            <div class="control-group">
                <label for="make">Make</label>
                <br>
                <select class="chosen" name="make" style="display: none;">
                    <option value="1">Jeep</option>
                    <option value="2">Range Rover</option>
                    <option value="3">ferrari</option>
                </select>
                <div class="chosen-container chosen-container-single" style="width: 200px;" title=""><a class="chosen-single"><span>Jeep</span><div><b></b></div></a>
                    <div class="chosen-drop">
                        <div class="chosen-search">
                            <input type="text" autocomplete="off">
                        </div>
                        <ul class="chosen-results"></ul>
                    </div>
                </div>
            </div>
            <br>
            <div class="control-group">
                <label for="Model">Model</label>
                <br>
                <input type="text" name="model" id="model">
            </div>
            <br>
            <div class="control-group">
                <label for="Trim">Trim</label>
                <br>
                <input type="text" name="trim" id="trim">
            </div>
            <br>
            <div class="control-group">
                <label for="Car_Image_s_">Car image(s)</label>
                <br>
                <input type="file" name="files[]" id="files_">
            </div>
            <br>
            <input type="submit" name="commit" value="Save changes">
        </form>

1 个答案:

答案 0 :(得分:0)

您是否正在编写所有这些内容?在HAML中,它看起来应该更像:

#openModal.modalDialog
  %div
    = link_to "Close", anchor: "close", class: "close"
    = form_tag cars_path, id: "car-form", multipart: true
      .control-group
        = label_tag "year"
        = text_field_tag "year"
      .control-group
        = label_tag "make"
        = select_tag "make", options_for_select(["Jeep","Range Rover","Ferrari"])
        .chosen-container.chosen-container-single
          .chosen-drop
            .chosen-search
              = text_field_tag "search", nil, autocomplete: 'off'
            %ul.chosen-results
      .control-group
        = label_tag "model"
        = text_field_tag "model"
      .control-group
        = label_tag "trim"
        = text_field_tag "trim"
      .control-group
        = label_tag "files", "Care Image(s)"
        = file_field_tag "files[]", multiple: true
      = submit_tag "Save changes"

我还没有测试过,所以可能会有一些错误。但是,如果您要使用HAML,您也可以使用HAML。

无论如何,为了回答你的问题,我的猜测是HAML正在解释:

<form id="car-form" enctype="multipart/form-data" action="/cars" accept-charset="UTF-8" method="post">

作为纯文本(因为<form ... >不是有效的HAML)。因此,当您这样做时:

<form id="car-form" enctype="multipart/form-data" action="/cars" accept-charset="UTF-8" method="post">
    <input name="utf8" type="hidden" value="✓">

第二行(也被解释为文本)会引发非法嵌套错误。

P.S。年度输入有样式。你应该在一个sass文件(或者你正在使用的任何样式格式)中真正做到这一点。

p.p.s。对您的真实性令牌进行硬编码似乎就好了。