角度 ui 路由器加载视图两次
Angular ui-router loading view twice
我在我的角度应用程序中使用了角度ui-router。对于我写的路由部分
var routerApp = angular.module('routerApp', ['ui.router']);
routerApp.config(function($stateProvider, $urlRouterProvider) {
$urlRouterProvider.otherwise('/home');
$stateProvider
// HOME STATES AND NESTED VIEWS ========================================
.state('home', {
url: '/home',
templateUrl: 'partial-home.html',
controller : function($scope,$state){
$scope.$on('$viewContentLoaded', function(){
console.log("home content loaded",$state.current);
})
}
})
// nested list with custom controller
.state('home.list', {
url: '/list',
template: 'I am using a list.'
})
// nested list with just some random string data
.state('home.paragraph', {
url: '/paragraph',
template: 'I could sure use a drink right now.'
})
});
在部分家庭中.html我已经写过:-
<div class="jumbotron text-center">
<h1>The Homey Page</h1>
<p>This page demonstrates <span class="text-danger">nested</span> views.</p>
<a ui-sref=".list" class="btn btn-primary">List</a>
<a ui-sref=".paragraph" class="btn btn-danger">Paragraph</a>
</div>
<div ui-view></div>
现在,当我在浏览器中执行此应用程序时,如果我打开路由
/home
浏览器控制台显示"已加载家庭内容"一次,然后如果我单击列表链接,地址栏将更改为
/home/list
然后控制台也显示一次。
但是如果我当时刷新浏览器选项卡(当路由是主页/列表时),控制台会显示两次。请帮助我为什么会发生这种事情。
这些是嵌套视图。重新加载后控制台中出现两条消息的原因是:从/home 开始时,将加载家乡状态。当你转到那边的/home/list 时,只需要加载 home.list,因为主状态已经加载。重新加载时,需要加载两种状态:home 和 home.list。
编辑:我没有足够的声誉,所以我无法发表评论。 我猜你在主页模板中使用 UI-View 会导致孩子和父共享相同的范围。 您正在收听孩子和家长的活动范围。 所以被叫两次是很自然
因为 home.list 是 home 的子状态,当您为 home.list 重新加载页面时它首先初始化主控制器的视图而不是列表控制器的视图,因此调用$viewContentLoaded两次
我猜你在主页模板中使用 UI-View,这会导致孩子和父共享相同的范围。 您正在收听子项和项
相关文章:
- Meteor Router数据函数被调用两次
- 从MySQL数据库中获取输入数据需要两次页面刷新
- Module.start()已激发两次
- Jquery点击事件必须点击两次
- Append元素在运行两次函数后不显示
- 防止双击执行两次jQuery post请求
- 我必须点击两次才能激活任何按钮操作(离子/角度)
- 骨干视图触发事件两次
- 触发的事件被接收两次.如何找到鬼视图
- 主干.js绑定到集合“添加”呈现视图两次
- ng单击需要两次才能更新视图
- 为什么同一个视图在Durandal日志中导航了两次
- 为什么主干视图触发更改事件两次
- 角度 ui 路由器加载视图两次
- 如果使用 AJAX 呈现部分视图,则 Ajax.BeginForm 发布两次
- 由于 ID 更改绑定,主干视图呈现两次
- 递归自定义树视图 angularjs 指令调用 ng 单击两次
- angular ui路由器-必须点击两次才能按预期更新视图(带演示)
- 无法调用$stateProvider两次来更新视图(它只在第一次工作)
- 主干木偶,渲染复合视图两次