用于创建两个布局和内容页面的js是:
$urlRouterProvider.otherwise("/Site/Movies");
$stateProvider
.state('admin', {
url: "/Admin",
templateUrl: "/Views/Admin.html"
})
.state('site', {
url: "/Site",
templateUrl: "/Views/Site.html"
})
.state('site.movies', {
url: "/Site/Movies",
templateUrl: "/Views/Site/movies.html",
controller: 'moviesController'
})
Index.html是:
<!DOCTYPE html>
<html ng-app="moviesApp">
<head></head>
<body ng-cloak>
<!--<div class="container-fluid">
<ng-view></ng-view>
</div>-->
<div ui-view></div>
<a ui-sref="site.movies">State 1</a>
</body>
</html>
&#13;
我删除了脚本引用。 Site.html是:
<header id="siteHeader">HEADER</header>
<div ui-view></div>
<footer id="siteFooter">FOOTER</footer>
&#13;
和movies.html
<div>
<h1>List Movies</h1>
<button ng-click="getMovies()">Get Movies</button>
<span>{{error}}</span>
<table class="table table-bordered table-striped">
<thead>
<tr>
<th></th>
<th>Title</th>
<th>Director</th>
</tr>
</thead>
<tbody>
<tr ng-repeat="movie in movies">
<td>
<a href="/movies/edit/{{movie.Id}}" class="btn btn-default btn-xs">edit</a>
<a href="/movies/delete/{{movie.Id}}" class="btn btn-danger btn-xs">delete</a>
</td>
<td>{{movie.Title}}</td>
<td>{{movie.Director}}</td>
</tr>
</tbody>
</table>
<p>
<a href="/movies/add" class="btn btn-primary">Add New Movie</a>
</p>
</div>
&#13;
我的问题是,当我点击sref =&#34; site.movies&#34;的链接时它出现,而不是在页面加载,我如何使movies.html及其布局加载网站首先运行。 当我在地址栏中输入/ site / movies时,movies.html也没有加载。
答案 0 :(得分:0)
我发现解决方案处于嵌套状态url:
.state('site.movies', {
url: "/Site/Movies",
templateUrl: "/Views/Site/movies.html",
controller: 'moviesController'
})
应该是:
.state('site.movies', {
url: "/Movies",
templateUrl: "/Views/Site/movies.html",
controller: 'moviesController'
})