angular.js - angular 如何刷新页面
淡淡烟草味
淡淡烟草味 2017-05-15 16:52:27
0
4
534

我使用$state.go();来切换页面
其中有些页面的数据是动态的,我希望每次进来都重新加载数据。
请问如何每次当切换到这个页面时都重新加载页面(重新执行controller中的方法)?
PS:

$state.go('page',null,{
    reload:true
});

这个也并没有效果

app.run(['$rootScope', '$location',
    function($rootScope, $location) {
        $rootScope.$on('$stateChangeStart', function(evt, next, current) {
            alert('route begin change');
        });
    }
]);

我在这里获得了state变化的事件 然而并不知道如何刷新$scope...

PS2:
我是这样实现的

$scope.$on('$stateChangeSuccess', function(evt, next, current) {
    // 数据reload
});

不知道算不算土办法...
但是这样也出现一个新的问题
$stateChangeSuccess中的方法会触发2遍,这是什么情况呢?

淡淡烟草味
淡淡烟草味

모든 응답(4)
洪涛

sessionStorage에 데이터를 저장할 수 있습니다. 그런 다음 아래 $on 청취 이벤트에서 방송하세요. 그런 다음 하위 계층 컨트롤러에서 이 브로드캐스트 이벤트를 수신합니다.

迷茫

특별한 처리가 필요하지 않습니다. 컨트롤러에 작성한 코드는 이 페이지로 전환할 때마다 자동으로 실행됩니다.

巴扎黑

컨트롤러는 상태가 바뀔 때마다 새로운 인스턴스를 생성합니다. 컨트롤러와 뷰는 새로운 인스턴스입니다. 이는 angularjs의 주입 아이디어와도 일치합니다. 컨트롤러 코드에 직접 기록할 수 있습니다.

迷茫

"$stateChangeSuccess의 메소드가 두 번 실행됩니다." 이는 뷰와 경로 모두에 컨트롤러 정보를 작성했기 때문입니다

최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿
회사 소개 부인 성명 Sitemap
PHP 중국어 웹사이트:공공복지 온라인 PHP 교육,PHP 학습자의 빠른 성장을 도와주세요!