私はangularjsの新しい蜂です。ユーザーがブラウザウィンドウを閉じようとしたときに警告する検証を作成しようとしています。
ページ v1 と v2 に 2 つのリンクがあります。リンクをクリックすると、特定のページに移動します。v1 と v2 にリダイレクトするコードは次のとおりです。
angular.module('myApp', ['myApp.filters', 'myApp.services', 'myApp.directives'])
.config(['$routeProvider', function($routeProvider) {
$routeProvider.when('/v1', {templateUrl: 'pages/v_1.html', controller: MyCtrl1});
$routeProvider.when('/v2', {templateUrl: 'pages/v_2.html', controller: MyCtrl2});
$routeProvider.otherwise({redirectTo: '/v1'});
}]);
ユーザーがv1をクリックしたときに、「彼が続行したい場合は、v1から離れようとしています」というメッセージをポップアップ表示したいと思います.v2をクリックしても同じです。これを達成する方法についての指針をいただければ幸いです。
ここで答えを得ましたが、時間間隔ごとにメッセージがポップアップします。
更新されたコード;
コントローラー
function MyCtrl1() {
$scope.$on('$locationChangeStart', function (event, next, current) {
if ('your condition') {
event.preventDefault();
MessageService.showConfirmation(
'Are you sure?',
MessageService.MessageOptions.YES_NO, {
'YES': function () {
blockNavigation = false;
$location.url($location.url(next).hash());
$rootScope.$apply();
},
'NO': function () {
MessageService.clear();
$log.log('NO Selected')
}
});
}
});
}
MyCtrl1.$inject = [];
function MyCtrl2() {}
MyCtrl2.$inject = [];