我一直致力于在Apple Mac机器上设置现有的Ionic 2项目。
我已按照here描述的方式复制了我的项目。
解决了一些Xcode问题后,最终应用程序在iPhone iOS物理设备上打开,但在启动画面后显示空白屏幕。
我找到了如何显示一些日志here。日志输入引导我SO thread: "cannot find module ionic-native"。
我总结说我必须更新我的项目代码以匹配new settings to handle ionic-native plugins。
对于每个插件,我应用了以下过程:ionic plugin rm [plugin name]
,ionic plugin add [plugin name]
,npm install --save @ionic-native/[plugin name]
。
我在一些components
和providers
中审核了我的代码,以便在需要的地方进行更改:
{ NativePlugin1, NativePlugin2 } from 'ionic-native';
至:
{ NativePlugin1 } from '@ionic-native/native-plugin-1';
{ NativePlugin2 } from '@ionic-native/native-plugin-2';
我修改了我的[离子项目文件夹] /src/app/app.module.ts并添加了:
// all declaration as it was like "import { NgModule } from '@angular/core';"
//plus declarations added to match new rules and add plugin in providers section
{ NativePlugin1 } from '@ionic-native/native-plugin-1';
{ NativePlugin2 } from '@ionic-native/native-plugin-2';
@NgModule({
declarations: [
...
],
imports: [...
],
bootstrap: [IonicApp],
entryComponents: [...
],
providers: [
NativePlugin1,
NativePlugin2,
...
]
})
export class AppModule {}
我从我的package.json中删除了solution of the SO thread I am referencing to中建议的行"ionic-native": "^2.7.0",
:
你需要删除" ionic-native":" ^ 3.5.0"从你的package.json开始,然后运行npm i。
然后我按顺序启动:sudo npm cache clear
,sudo npm install
,最后ionic build ios
,我得到了:
"错误:无法转换程序"
在此错误之上,我发现有很多与此ionic-native
相关的错误:
[14:22:15] typescript:src / services / custom-http / custom-http.ts,line:XX
Property 'type' does not exist on type 'typeof Network'. LXX: return Network.type;
我现在感到困惑,所以如果有人提示它会受到欢迎。
要完成此处还有一些其他信息:
ionic info
给出:
Cordova CLI: 6.5.0
Ionic Framework Version: 2.0.0-rc.0
Ionic CLI Version: 2.2.3
Ionic App Lib Version: 2.2.1
Ionic App Scripts Version: 1.3.4
ios-deploy version: 1.9.1
ios-sim version: 5.0.13
OS: macOS Sierra
Node Version: v6.9.1
Xcode version: Xcode 7.3.1 Build version 7D1014
我的package.json
是这样的:
{
"name": "my project",
"author": "my name",
"homepage": "",
"private": true,
"scripts": {
"build": "ionic-app-scripts build",
"watch": "ionic-app-scripts watch",
"serve:before": "watch",
"emulate:before": "build",
"deploy:before": "build",
"build:before": "build",
"run:before": "build"
},
"dependencies": {
"@angular/common": "2.0.0",
"@angular/compiler": "2.0.0",
"@angular/compiler-cli": "0.6.2",
"@angular/core": "2.0.0",
"@angular/forms": "2.0.0",
"@angular/http": "2.0.0",
"@angular/platform-browser": "2.0.0",
"@angular/platform-browser-dynamic": "2.0.0",
"@angular/platform-server": "2.0.0",
"@ionic-native/core": "^3.5.0",
"@ionic-native/device": "^3.5.0",
"@ionic-native/insomnia": "^3.5.0",
"@ionic-native/keyboard": "^3.5.0",
"@ionic-native/network": "^3.5.0",
"@ionic-native/screen-orientation": "^3.5.0",
"@ionic-native/splash-screen": "^3.5.0",
"@ionic-native/sqlite": "^3.5.0",
"@ionic-native/status-bar": "^3.5.0",
"@ionic-native/vibration": "^3.5.0",
"@ionic/storage": "1.0.3",
"ionic-angular": "2.0.0-rc.0",
"ionicons": "3.0.0",
"ng2-translate": "^3.2.1",
"rxjs": "5.0.0-beta.12",
"zone.js": "0.6.21"
},
"devDependencies": {
"@ionic/app-scripts": "latest",
"typescript": "2.0.3"
},
"description": "MyProject: An Ionic project",
"cordovaPlugins": [
"cordova-plugin-device",
"cordova-plugin-console",
"cordova-plugin-whitelist",
"cordova-plugin-splashscreen",
"cordova-plugin-statusbar",
"ionic-plugin-keyboard"
],
"cordovaPlatforms": []
}
@suraj输入后的一些更新: 我已经更新了我的package.json,例如:
{
"name": "MyIonicProject",
"author": "author name",
"homepage": "",
"private": true,
"scripts": {
"build": "ionic-app-scripts build",
"watch": "ionic-app-scripts watch",
"serve:before": "watch",
"emulate:before": "build",
"deploy:before": "build",
"build:before": "build",
"run:before": "build"
},
"dependencies": {
"@angular/common": "4.0.0",
"@angular/compiler": "4.0.0",
"@angular/compiler-cli": "4.0.0",
"@angular/core": "4.0.0",
"@angular/forms": "4.0.0",
"@angular/http": "4.0.0",
"@angular/platform-browser": "4.0.0",
"@angular/platform-browser-dynamic": "4.0.0",
"@angular/platform-server": "4.0.0",
"@ionic-native/core": "^3.5.0",
"@ionic-native/device": "^3.5.0",
"@ionic-native/insomnia": "^3.5.0",
"@ionic-native/keyboard": "^3.5.0",
"@ionic-native/network": "^3.5.0",
"@ionic-native/screen-orientation": "^3.5.0",
"@ionic-native/splash-screen": "^3.5.0",
"@ionic-native/sqlite": "^3.5.0",
"@ionic-native/status-bar": "^3.5.0",
"@ionic-native/vibration": "^3.5.0",
"@ionic/storage": "2.0.1",
"ionic-angular": "3.0.1",
"ionicons": "3.0.0",
"rxjs": "5.1.1",
"sw-toolbox": "3.4.0",
"zone.js": "^0.8.4",
"ng2-translate": "^3.2.1"
},
"devDependencies": {
"@ionic/app-scripts": "latest",
"typescript": "~2.2.1"
},
"description": "LpjcaIonic: An Ionic project",
"cordovaPlugins": [
"cordova-plugin-device",
"cordova-plugin-console",
"cordova-plugin-whitelist",
"cordova-plugin-splashscreen",
"cordova-plugin-statusbar",
"ionic-plugin-keyboard"
],
"cordovaPlatforms": []
}
我跟着change log update for ionic 3。
我删除了项目启动的node_modules
目录:sudo rm -rf node_modules/
然后执行了nom install
,ionic platform rm ios
,ionic platform add ios
,最后ionic build ios
我查看了日志,这是他们的内容:
0 info it worked if it ends with ok
1 verbose cli [ '/usr/local/bin/node', '/usr/local/bin/npm', 'run', 'build' ]
2 info using npm@4.5.0
3 info using node@v6.9.1
4 verbose run-script [ 'prebuild', 'build', 'postbuild' ]
5 info lifecycle [MyIonicProject]@~prebuild: [MyIonicProject]@
6 silly lifecycle [MyIonicProject]@~prebuild: no script for prebuild, continuing
7 info lifecycle [MyIonicProject]@~build: [MyIonicProject]@
8 verbose lifecycle [MyIonicProject]@~build: unsafe-perm in lifecycle true
9 verbose lifecycle [MyIonicProject]@~build: PATH: /usr/local/lib/node_modules/npm/bin/node-gyp-bin:/Users/my_mac/Documents/[MyIonicProject]/node_modules/.bin:/usr/local/bin:/usr/bin:/bin:/usr/sbin:/sbin:/usr/local/bin:/Users/my_mac/Library/Android/sdk:/Users/my_mac/Library/Android/sdk/tools:/Users/my_mac/Library/Android/sdk/platform-tools
10 verbose lifecycle [MyIonicProject]@~build: CWD: /Users/my_mac/Documents/[MyIonicProject]
11 silly lifecycle [MyIonicProject]@~build: Args: [ '-c', 'ionic-app-scripts build' ]
12 silly lifecycle [MyIonicProject]@~build: Returned: code: 1 signal: null
13 info lifecycle [MyIonicProject]@~build: Failed to exec build script
14 verbose stack Error: [MyIonicProject]@ build: `ionic-app-scripts build`
14 verbose stack Exit status 1
14 verbose stack at EventEmitter.<anonymous> (/usr/local/lib/node_modules/npm/lib/utils/lifecycle.js:279:16)
14 verbose stack at emitTwo (events.js:106:13)
14 verbose stack at EventEmitter.emit (events.js:191:7)
14 verbose stack at ChildProcess.<anonymous> (/usr/local/lib/node_modules/npm/lib/utils/spawn.js:40:14)
14 verbose stack at emitTwo (events.js:106:13)
14 verbose stack at ChildProcess.emit (events.js:191:7)
14 verbose stack at maybeClose (internal/child_process.js:877:16)
14 verbose stack at Process.ChildProcess._handle.onexit (internal/child_process.js:226:5)
15 verbose pkgid LpjcaIonic@
16 verbose cwd /Users/my_mac/Documents/[MyIonicProject]
17 verbose Darwin 16.5.0
18 verbose argv "/usr/local/bin/node" "/usr/local/bin/npm" "run" "build"
19 verbose node v6.9.1
20 verbose npm v4.5.0
21 error code ELIFECYCLE
22 error errno 1
23 error LpjcaIonic@ build: `ionic-app-scripts build`
23 error Exit status 1
24 error Failed at the [MyIonicProject]@ build script 'ionic-app-scripts build'.
24 error Make sure you have the latest version of node.js and npm installed.
24 error If you do, this is most likely a problem with the [MyIonicProject] package,
24 error not with npm itself.
24 error Tell the author that this fails on your system:
24 error ionic-app-scripts build
24 error You can get information on how to open an issue for this project with:
24 error npm bugs [MyIonicProject]
24 error Or if that isn't available, you can get their info via:
24 error npm owner ls [MyIonicProject]
24 error There is likely additional logging output above.
25 verbose exit [ 1, true ]
@suraj的附加输入,即班级CustomHttpService
,它是[project]/services/custom-http/custom-http.ts
中的一项服务,并注入Providers
的{{1}}部分:
app.module.ts
答案 0 :(得分:2)
您已将ionic-native更新为3.x ..但是您的核心ionic-angular
仍在2.0.0-rc0
中,并且所有其他依赖项都较旧。
目前使用的打字稿更改为2.2。
如果您打算转移到离子原生3,则需要将package.json更新为当前starter app version。
同时检查changelog代码中离子的任何重大变化。
此外,您需要将每个离子本机插件设置为提供程序并注入构造函数并使用。 检查the docs。 在app.module.ts中,
@NgModule({
...
providers: [
...
Network
...
]
...
})
export class AppModule { }
在custom.http.ts
中constructor(public http:Http,public network:Network
){
console.log("CustomHttpService() starts");
}
//..other code
public connection = () => {
return this.network.type;
}
答案 1 :(得分:0)
遇到同样的错误,在过滤完代码后,语法错误,缺少逗号。尝试查看app.module.ts文件。希望它有所帮助。