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

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

新規登録して質問してみよう
ただいま回答率
85.48%
Scala

ScalaはJava仮想マシンで動作を行うオブジェクト指向型プログラミング言語の1つです。静的型付けの関数型言語で、コンパイルエラーの検出に強みがあります。

Play Framework

Play Frameworkは、現代の web アプリケーション開発に必要なコンポーネント及び API を統合した生産性の高い Java と Scala の web アプリケーションフレームワークです。

Q&A

0回答

545閲覧

not found: type MessagesRequestHeader 解決

nbki

総合スコア3

Scala

ScalaはJava仮想マシンで動作を行うオブジェクト指向型プログラミング言語の1つです。静的型付けの関数型言語で、コンパイルエラーの検出に強みがあります。

Play Framework

Play Frameworkは、現代の web アプリケーション開発に必要なコンポーネント及び API を統合した生産性の高い Java と Scala の web アプリケーションフレームワークです。

0グッド

0クリップ

投稿2021/07/09 10:20

編集2021/07/09 10:48

not found: type MessagesRequestHeader のエラー解決

Scala/PlayFrameworkを学習中です。
現在、slickを使いデータベースからデータをテンプレートに表示する作業を行っています。
タイプミスは確認しましたがないと思います。何が原因でのエラーか理解できていません。
よろしくお願い致します。

発生している問題・エラーメッセージ

not found: type MessagesRequestHeader

build.sbt

name := """play/slickApp""" organization := "con.example" version := "1.0-SNAPSHOT" lazy val root = (project in file(".")).enablePlugins(PlayJava) scalaVersion := "2.12.6" libraryDependencies += guice libraryDependencies += "org.scalatextplus.play" %% "scalatextplus-play" % "3.1.2" % "Test" libraryDependencies += "com.h2database" % "h2" % "1.4.197" libraryDependencies += "com.typesafe.play" %% "play-slick" % "3.0.3" libraryDependencies += "com.typesafe.play" %% "play-slick-evolutions" % "3.0.3"

HomeController.scala (コントローラ)

package controllers import javax.inject._ import models._ import play.api.data.Form import play.api.data.Forms._ import play.api.data.validation.Constraints._ import play.api.i18n._ import play.api.libs.json.Json import play.api.mvc._ import scala.concurrent.{ExecutionContext, Future} @Singleton class HomeController @Inject()(repository: PersonRepository, cc: MessagesControllerComponents) (implicit ec:ExecutionContext) extends MessagesAbstractController(cc) { def index() = Action.async { implicit request => repository.list().map { implicit people => Ok(views.html.index( "People Data", people )) } }

Person.scala (モデル)

package models import play.api.data.Form import play.api.data.Forms._ object Person { val personform: Form[PersonForm] = Form { mapping( "name" -> text, "mail" -> text, "tel" -> text )(PersonForm.apply)(PersonForm.unapply) } } case class Person(id: Int, name: String, mail: String, tel: String) case class PersonForm(name: String, mail: String, tel: String)

index.scala.html (テンプレート)

@(message: String, data: Seq[models.Person])(implicit request: MessagesRequestHeader) @main("Index Page", "Hello!", "copyright 2021.") { <p>@Html(message)</p> <ul> @for(item <- data) { <li>@item.id: @item.name [@item.mail, @item.tel]</li> } </ul> }

PresonRepository.scala (リポジトリ)

package models import javax.inject.{ Inject, Singleton } import play.api.db.slick.DatabaseConfigProvider import slick.jdbc.JdbcProfile import scala.concurrent.{ Future, ExecutionContext } @Singleton class PersonRepository @Inject() (dbConfigProvider: DatabaseConfigProvider) (implicit ec: ExecutionContext) { private val dbConfig = dbConfigProvider.get[JdbcProfile] import dbConfig._ import profile.api._ private class PeopleTable(tag: Tag) extends Table[Person](tag, "people") { def id = column[Int]("id", O.PrimaryKey, O.AutoInc) def name = column[String]("name") def mail = column[String]("mail") def tel = column[String]("tel") def * = (id, name, mail, tel) <> ((Person.apply _).tupled, Person.unapply) } private val people = TableQuery[PeopleTable] def list(): Future[Seq[Person]] = db.run { people.result } }

バージョン

Scala 2.12.6
Play 1.0-SNAPSHOT
H2 1.4.197
slick 3.0.3
slick-evolutions 3.0.3

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

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

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

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

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

guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだ回答がついていません

会員登録して回答してみよう

アカウントをお持ちの方は

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問