【发布时间】:2017-02-11 15:47:39
【问题描述】:
我想在每次页面更改时执行一些代码。
我可以为每个页面添加一个ngOnDestroy 方法。看来我可以使用 Ionic 2 页面 lifecycle hooks(例如 ionViewDidUnload)获得完全相同的效果,但我没有费心去测试它。我宁愿在主应用程序类中添加一个方法。
我看到你可以订阅 Angular 2 Router events。我如何翻译它以在 Ionic 2 中使用?我首先收到import { Router } from '@angular/router; 的错误:
TypeScript error: <path>/node_modules/@angular/router/src/common_router_providers.d.ts(9,55): Error TS2305: Module '"<path>/node_modules/@angular/core/index"' has no exported member 'NgModuleFactoryLoader'.
TypeScript error: <path>/node_modules/@angular/router/src/router.d.ts(14,39): Error TS2305: Module '"<path>/node_modules/@angular/core/index"' has no exported member 'NgModuleFactoryLoader'.
TypeScript error: <path>/node_modules/@angular/router/src/router_module.d.ts(9,10): Error TS2305: Module '"<path>/node_modules/@angular/core/index"' has no exported member 'ModuleWithProviders'.
webpack 配置
var path = require('path');
module.exports = {
entry: [
path.normalize('es6-shim/es6-shim.min'),
'reflect-metadata',
path.normalize('zone.js/dist/zone'),
path.resolve('app/app.ts')
],
output: {
path: path.resolve('www/build/js'),
filename: 'app.bundle.js',
pathinfo: false // show module paths in the bundle, handy for debugging
},
module: {
loaders: [
{
test: /\.ts$/,
loader: 'awesome-typescript',
query: {
doTypeCheck: true,
resolveGlobs: false,
externals: ['typings/browser.d.ts']
},
include: path.resolve('app'),
exclude: /node_modules/
}
],
noParse: [
/es6-shim/,
/reflect-metadata/,
/zone\.js(\/|\\)dist(\/|\\)zone/
]
},
resolve: {
alias: {
'angular2': path.resolve('node_modules/angular2')
},
extensions: ["", ".js", ".ts"]
}
};
无论如何,如果有办法使用 ionic-angular 的 Nav 或 NavController 服务,那对我来说会更有意义。有没有办法做到这一点?
【问题讨论】:
标签: angular typescript ionic-framework ionic2 ionic3