質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.47%
Ruby on Rails 5

Ruby on Rails 5は、オープンソースのWebアプリケーションフレームワークです。「同じことを繰り返さない」というRailsの基本理念のもと、他のフレームワークより少ないコードで簡単に開発できるよう設計されています。

Ruby on Rails

Ruby on Railsは、オープンソースのWebアプリケーションフレームワークです。「同じことを繰り返さない」というRailsの基本理念のもと、他のフレームワークより少ないコードで簡単に開発できるよう設計されています。

Q&A

解決済

1回答

2367閲覧

haml:3: syntax error, unexpected tLABEL, expecting '='

kossytera

総合スコア13

Ruby on Rails 5

Ruby on Rails 5は、オープンソースのWebアプリケーションフレームワークです。「同じことを繰り返さない」というRailsの基本理念のもと、他のフレームワークより少ないコードで簡単に開発できるよう設計されています。

Ruby on Rails

Ruby on Railsは、オープンソースのWebアプリケーションフレームワークです。「同じことを繰り返さない」というRailsの基本理念のもと、他のフレームワークより少ないコードで簡単に開発できるよう設計されています。

0グッド

0クリップ

投稿2018/08/07 21:24

編集2018/08/08 20:43

タイトルのエラーが出て困っております。
ググるとdoのつけ忘れが原因との回答もありましたが、doは付記してあるので、
何か別のところに原因がありそうです

以下該当ソースコード

.contents.row .container = form_for (@review, url: reviews_path) do |f| - if review.errors.any? .form__errors %h2= "#{review.errors.full_messages.count}errors occurred." %ul - review.errors.full_messages.each do |message| %li = message = f.label 'bookName' = f.text_field :name, class: 'form-item1', placeholder: 'bookName' = f.label 'レベル' = f.text_field :level, class: 'form-item2', placeholder: '初級・中級・上級' = f.label '画像' = f.text_field :image, class: 'form-item3', placeholder: 'imageUrl' = f.label 'レビュー' = f.text_field :content, class: 'form-item4', placeholder: '本文' = f.submit

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

takahashim

2018/08/08 16:27

さすがにHamlのソースコードのインデントがないと解読が不可能になるので、ソースコードはメニューの「<code>」、コードの挿入機能を使って書いていただけないでしょうか。
kossytera

2018/08/08 20:43

大変失礼いたしました。編集しました。
guest

回答1

0

ベストアンサー

これはRubyの癖のあるところで、メソッドの引数のカッコとメソッド名の間には余計な空白を入れないようにしてください。

haml

1.contents.row 2 .container 3 = form_for(@review, url: reviews_path) do |f| 4 - if @review.errors.any? 5 .form__errors 6 %h2= "#{@review.errors.full_messages.count}errors occurred." 7 %ul 8 - @review.errors.full_messages.each do |message| 9 %li = message 10(以下略)

こうしないと、url: reviews_pathがform_forの第2引数ではなく、第1引数の一部と見なされてしまうのでした。

あるいは以下のように、自明なカッコを省略するのでも可です。

haml

1.contents.row 2 .container 3 = form_for @review, url: reviews_path do |f| 4 - if @review.errors.any? 5 .form__errors 6 %h2= "#{@review.errors.full_messages.count}errors occurred." 7 %ul 8 - @review.errors.full_messages.each do |message| 9 %li = message 10 11(以下略)

なお、ついでに一部review@reviewに直してみています。

投稿2018/08/09 15:59

takahashim

総合スコア1877

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.47%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問