[英]Play Framework 2.1.0 & AngularJS Integration
1)我想将AngularJS与Play Framework 2.1.0结合使用,将Play服务JSON内容作为RESTful服务器后端,它从版本1.x迁移到2.x后出现,无法为静态HTML服务内容来自使用以下方法的Public文件夹:
Routes.conf:
GET / staticFile:/public/index.html
这导致Controller方法调用预期异常被引发。
我发现在Play 2.1.0中工作的一种方法是在Controller中编写一个Action方法,如下所示:
public static Result index() {
return ok(Play.application().getFile("public/index.html"));
}
这是最好的方法还是有更优雅和功能性的解决方案?
2)在使用客户端JavaScript框架而不是基于Scala的模板引擎的方法中是否存在任何潜在的缺点或“陷阱”?
任何指针都将非常感激。
使用Angular路由时,一种方法是使用Play为索引页面提供服务,并将部分内容作为公共目录中的静态资源提供。 routes
文件将包含以下内容:
GET / controllers.Application.index
GET /assets/*file controllers.Assets.at(path="/public", file)
Play控制器看起来像:
def index = Action {
Ok(views.html.index())
}
这允许您使用Plays模板进行资源导入(它也可以很好地与WebJars一起使用 )。 例如,在index.scala.html
:
<script src="@routes.Assets.at("javascripts/app.js")" type="text/javascript"></script>
<script type='text/javascript' src='@routes.WebJarAssets.at(WebJarAssets.locate("angular.min.js"))'></script>
然后,您可以将所有部分放在公共目录中并将它们作为静态文件提供,这些可以从您的app.js中引用,如下所示:
when('/partial-1', {templateUrl: '/assets/partials/partial-1.html', controller: CtrlPartial1}).
当文件在public
文件夹,你可以使用简单的访问它们/assets/*
的URL。 你也可以这样做:
GET /view/*file controllers.Assets.at(path="/public/angular", file)
Morover,我会说,即使它是静态的,你也可能希望将来动态生成一些数据。 所以你可以做的就是将HTML文件创建为经典模板很简单,比方说: ang/index.scala.html
。 然后您的路线和控制器将如下所示:
路线:
GET / controllers.Application.angView()
控制器:
public static Result index() {
return ok(views.html.ang.index(/*some data here?*/));
}
我喜欢使用客户端生成的东西的客户端视图,以及服务器端视图来准备字段,注入在整个应用程序生命周期中应该使用的所有相关数据。
最终种子( https://github.com/angyjoe/eventual )完全提供public
文件夹中的静态HTML页面,同时使Play routes
脚本文件几乎完好无损。
种子最少使用Play Scala模板,以便为HTML中的AngularJS指令清除空间。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.