0

我正在使用 scalajs-react 应用程序。我拥有的 UI 字段之一是多行文本的输入字段,它映射到状态对象的属性。状态对象定义:

case class Person(name: String, addresses: Seq[String])

我有相应的地址 UI 字段为:

 <.label("Addresses:",
              <.input(^.`type` := "text", ^.cls := "form-control",
                ^.value := person.addresses.mkString("\n"), ^.onChange ==> updateAddresses))

def updateAddresses(event: ReactEventFromInput): Callback = {
    val updatedAddresses = event.target.value.split("\\\\n").toSeq // based on some google search
    $.modState(prev => prev.copy(addresses = updatedAddresses))
  }

但似乎它不起作用。我无法在 UI 上添加换行符。

如何实现?

4

1 回答 1

0

您必须使用textareahtml 标签进行多行文本输入。(见https://www.w3schools.com/tags/tag_textarea.asp

这有效:

<.label("Addresses:",
          <.textarea(^.`type` := "text", ^.cls := "form-control",
            ^.value := person.addresses.mkString("\n"), ^.onChange ==> updateAddresses))
于 2021-10-11T20:25:07.957 回答