NativeScript处理后退按钮事件

时间:2016-11-15 06:39:50

标签: nativescript back-button angular2-nativescript

我正在尝试处理NativeScript应用中的硬件后退按钮。我使用带有Angular的NativeScript版本2.3.0。

以下是我在main.ts档案中的内容

// this import should be first in order to load some required settings (like globals and reflect-metadata)
import { platformNativeScriptDynamic, NativeScriptModule } from "nativescript-angular/platform";
import { NgModule,Component,enableProdMode } from "@angular/core";
import { AppComponent } from "./app.component";
import { NativeScriptRouterModule } from "nativescript-angular/router";
import { routes, navigatableComponents } from "./app.routing";
import { secondComponent } from "./second.component";
import {AndroidApplication} from "application";
@Component({
    selector: 'page-navigation-test',
    template: `<page-router-outlet></page-router-outlet>`
})
export class PageNavigationApp {
}
@NgModule({
    declarations: [AppComponent,PageNavigationApp,secondComponent
        // ...navigatableComponents
        ],
    bootstrap: [PageNavigationApp],
    providers:[AndroidApplication],
    imports: [NativeScriptModule,
        NativeScriptRouterModule,
    NativeScriptRouterModule.forRoot(routes)
    ],
})
class AppComponentModule {

    constructor(private androidapplication:AndroidApplication){
        this.androidapplication.on("activityBackPressed",()=>{
            console.log("back pressed");

        })
    }

}

enableProdMode();

platformNativeScriptDynamic().bootstrapModule(AppComponentModule);

我正在使用

导入应用程序

import {AndroidApplication} from "application";

然后在appComponentModule的constrouctor中,我正在为activityBackPressed注册事件,只是在做一个console.log。

这不起作用。

我在这里缺少什么?

4 个答案:

答案 0 :(得分:25)

我也使用带有Angular的NativeScript,这对我来说似乎很有效:

import { RouterExtensions } from "nativescript-angular";
import * as application from "application";
import { AndroidApplication, AndroidActivityBackPressedEventData } from "application";
import { isAndroid } from "platform";

export class HomeComponent implements OnInit {
  constructor(private router: Router) {}

  ngOnInit() {
    if (!isAndroid) {
      return;
    }
    application.android.on(AndroidApplication.activityBackPressedEvent, (data: AndroidActivityBackPressedEventData) => {
      if (this.router.isActive("/articles", false)) {
        data.cancel = true; // prevents default back button behavior
        this.logout();
      }
    });
  }
}

请注意,挂钩到backPressedEvent是一个全局性的东西,因此根据上面的示例,您需要检查您所在的页面并采取相应的行动。

答案 1 :(得分:1)

通常你应该有一个android活动并在该活动上声明backpress功能。仅使用AndroidApplication是不够的。试试这段代码:

import {topmost} from "ui/frame";
import {AndroidApplication} from "application";

let activity = AndroidApplication.startActivity ||
            AndroidApplication.foregroundActivity ||
            topmost().android.currentActivity ||
            topmost().android.activity;

activity.onBackPressed = function() {
    // Your implementation
}

您还可以查看此snippet例如

答案 2 :(得分:0)

import { Component, OnInit } from "@angular/core";
import * as Toast from 'nativescript-toast';
import { Router } from "@angular/router";
import * as application from 'application';

@Component({
  moduleId: module.id,
  selector: 'app-main',
  templateUrl: './main.component.html',
  styleUrls: ['./main.component.css']
})
export class MainComponent {
  tries: number = 0;
  constructor(
    private router: Router
  ) {
    if (application.android) {
      application.android.on(application.AndroidApplication.activityBackPressedEvent, (args: any) => {
        if (this.router.url == '/main') {
          args.cancel = (this.tries++ > 0) ? false : true;
          if (args.cancel) Toast.makeText("Press again to exit", "long").show();
          setTimeout(() => {
            this.tries = 0;
          }, 2000);
        }
      });
    }
  }
}

答案 3 :(得分:0)

据我所知,NativeScript具有对此的内置支持,但根本没有记录。 使用onBackPressed回调,您可以处理View组件的后退按钮行为(例如Frame,Page,BottomNavigation)。

示例:

function pageLoaded(args) {
  var page = args.object;
  page.onBackPressed = function () {
    console.log("Returning true will block back button default behaviour.");
    return true;
  };
  page.bindingContext = homeViewModel;
}

exports.pageLoaded = pageLoaded;

这里比较棘手的是找出应用程序中哪个视图可以处理后退按钮的按下。就我而言,我使用的TabView包含页面,但是TabView本身处理事件而不是当前页面。