如何将scala列表转换为javascript数组?

时间:2013-03-20 10:15:11

标签: javascript scala playframework-2.0 scala-template

有更简单的方法吗?

 $(document).ready(function () {
        var jsArray = []
        @if(scalaList != null) {
            @for(id <- scalaList) {
            jsArray.push('@id');
           }
        }
    ...
    }

4 个答案:

答案 0 :(得分:8)

它简单如下:

import play.api.libs.json.Json

val jsArr: JsValue = Json.toJson(scalaList)

您也可以在模板中执行此操作:

@(list: List[Any])

@import play.api.libs.json.Json

<script type="text/javascript">
    $(document).ready(function () {
        var jsArr = @Json.toJson(list);
        console.log(jsArr);
    });
</script>

答案 1 :(得分:3)

你可以使用mkString。

  $(document).ready(function () {
    var jsArray = @if(scalaList != null) {
      [ @scalaList.mkString(",") ]} 
    else {[]};
  }

您应该在视图中省略此if语句。而不是这个,在控制器中检查null并将空列表放到视图中,因此这个代码在视图中可以更简单

 $(document).ready(function () {
    var jsArray = [ @scalaList.mkString(",") ];
 }

你不需要这个引号''围绕id。在javascript 1 =='1'是真的

答案 2 :(得分:2)

你有没有试过像:

var jsArray = new Array(@scalaList.map(x => "\"" + x + "\"").mkString(","));

或者您可以使用像

这样的文字
var jaArray = [    var jsArray = [@scalaList.map(x => "\"" + x + "\"").mkString(",")];

此外,不需要if检查。 For理解就像那样聪明

$(document).ready(function () {
    var jsArray = [@scalaList.map(x => "\"" + x + "\"").mkString(",")];
    ...
}

答案 3 :(得分:2)

我认为每个答案都很好,但仍然不安全,因为每个答案都不关心包含'或'的价值。幸运的是,播放框架支持json,所以你应该使用json转换为javascript数组。

 @(json: String)
 <html>
 <head>
 </head>
 <body>
 <script>
 var json = @Html(json);
 var list = json.list;
 </script>
 </body>
 </html>
 package controllers

 import play.api._
 import play.api.libs.json._
 import play.api.mvc._

 object Application extends Controller {

   def index = Action {
     val list = List( "hoge\"hoge", "moge'mo\"ge" )
     val json = Json.stringify( Json.obj( 
       "list" -> JsArray( list.map( JsString(_) ) )
     ))
     Ok(views.html.index(json))
   }

 }