导航器警报功能第二次工作

ben*_*zra 5 jquery angularjs cordova

单击时我有一个按钮我执行此功能:

$scope.sendPolicy = function(){
    // make server request and called this call back:
    navigator.notification.alert(
        "message",
        function(){
            $state.transitionTo('main', {
                Id: $scope.Id
                });
        },
        'title',
        'confirm');
Run Code Online (Sandbox Code Playgroud)

弹出警报确定,但单击确认按钮时,警报会消失,就是这样.没有其他事情发生(应该触发向主屏幕的过渡.)在警报被解除后,如果再次点击导致警报弹出的按钮,视图/页面传输正在被触发,我们回到主要页面,以及警报再次弹出.

问题是:

  1. 为什么确认按钮不会触发回弹/转移到主屏幕.
  2. 为什么另一个按钮会导致弹出/转移?
  3. 为什么这个额外的点击会再次触发警报?

Jar*_*ves 1

  1. 我认为这是在角度范围之外获得确认时角度不更新的问题。看来您可能需要手动运行摘要/应用,以便 Angular 可以更新范围。

  2. 当再次单击按钮时,Angular 正在运行更新,现在范围具有转换信息,但它也会再次调用警报,因为这将是一个单独的单击事件。

  3. 2中解释过。

为了解决这个问题,我认为你需要在某个时候调用 $scope.apply() ,如下所示:

 $scope.sendPolicy = function(){
// make server request and called this call back:
navigator.notification.alert(
    "message",
    function(){
        $state.transitionTo('main', {
            Id: $scope.Id
            });
    if(!$scope.$$phase){$scope.$apply();}        
    },
    'title',
    'confirm');
Run Code Online (Sandbox Code Playgroud)

或者在警报函数结束时调用它。

注意:您可以将其称为 $scope.$apply(),但是如果摘要已经在进行中,这可能会引发错误,因此调用此方法的安全方法是 if(!$scope.$$phase){$scope .$apply();} 仅在未进行时才调用。