2016-10-19 7 views
-1

主に私は常にerbを使用していますので、私は使用しません。 エラーはフォームの後ろにあり、スペースではなくタブを使用しています。なぜこれがうまくいかないのか?Haml -Illegalネスティング:プレーンテキスト内でのネストは無効ですruby on rails

%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> 
+0

これは完全にHAMLではないようです。 –

+0

@DavidAldridge Hamlでは、通常のhtmlタグを使用することもできます。問題は字下げである。 –

答えて

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を使うかもしれません。プレーンテキストとして

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

<form ... >がHAML有効ではありませんので):

はとにかく、あなたの質問に答えるために、私の推測では、HAMLが解釈されていることです。したがって、これを行うとき:

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

2行目(これもテキストとして解釈されます)は、不正なネストエラーをスローします。

p.s.年の入力のためのスタイリングがあった。あなたは本当にそれをsassファイル(またはあなたが使っているどのようなスタイルフォーマットでも)で行うべきです。

p.p.s.信頼性の高いトークンをハードコーディングすると、破損するようです。

+0

私はそれを試してみましたが、私はそれを達成できませんでしたので、私はハードコードする必要がありました。 –

+0

私はちょうど答えに追加しました。 HAMLがハードコードされたものを解釈するのを止めるために、 ':plain'フィルタを使うことができるかもしれません。しかし、あなたは本当に、HAMLがそれが想定されている方法で動作するようにする必要があります。 – jvillian

+0

ありがとう、私はあなたが通常のタグを使うことができることを知っていたのでもっと意味があります。 –

関連する問題