我正在尝试创建一个基于ngx-translate(i18n)库的多语言NativeScript应用程序,我知道NPM上有几个其他插件,但它们都存在一些问题或不支持Angular 5,所以我决定使用这个库
我只是在nativescript-angular angular模板上创建了一个简单的应用程序,并将ngx-translate实现到我的项目中,并在应用程序根文件夹中设置了我的JSON文件
./assets/i18n/
但是一旦我运行我的项目,就会出现一些错误。
System.err: java.net.MalformedURLException: no protocol: ./assets/i18n/en.json
和其他错误
JS: ERROR Error: Uncaught (in promise): [object Object]
这是我在 Package.json
文件中的依赖项
"dependencies": {
"@angular/animations": "~5.2.1",
"@angular/common": "~5.2.1",
"@angular/compiler": "~5.2.1",
"@angular/core": "~5.2.1",
"@angular/forms": "~5.2.1",
"@angular/http": "~5.2.1",
"@angular/platform-browser": "~5.2.1",
"@angular/platform-browser-dynamic": "~5.2.1",
"@angular/router": "~5.2.1",
"@ngx-translate/core": "^9.1.1",
"@ngx-translate/http-loader": "^2.0.1",
"nativescript-angular": "~5.2.0",
"nativescript-barcodescanner": "2.7.4",
"nativescript-cardview": "2.0.5",
"nativescript-fancyalert": "^1.1.2",
"nativescript-feedback": "^1.1.0",
"nativescript-google-maps-sdk": "^2.4.3",
"nativescript-pro-ui": "~3.3.0",
"nativescript-theme-core": "~1.0.4",
"reflect-metadata": "~0.1.10",
"rxjs": "~5.5.5",
"tns-core-modules": "~3.4.0",
"zone.js": "~0.8.18"
},
"devDependencies": {
"@angular/compiler-cli": "~5.2.1",
"@ngtools/webpack": "~1.9.1",
"babel-traverse": "6.26.0",
"babel-types": "6.26.0",
"babylon": "6.18.0",
"codelyzer": "~4.0.2",
"copy-webpack-plugin": "~4.3.0",
"css-loader": "~0.28.7",
"extract-text-webpack-plugin": "~3.0.2",
"lazy": "1.0.11",
"nativescript-dev-sass": "~1.3.5",
"nativescript-dev-typescript": "~0.6.0",
"nativescript-dev-webpack": "~0.9.0",
"nativescript-worker-loader": "~0.8.1",
"raw-loader": "~0.5.1",
"resolve-url-loader": "~2.2.1",
"sass-loader": "~6.0.6",
"tslint": "~5.9.1",
"typescript": "~2.6.2",
"uglifyjs-webpack-plugin": "~1.1.6",
"webpack": "~3.10.0",
"webpack-bundle-analyzer": "^2.9.1",
"webpack-sources": "~1.1.0"
}
}
这是我的app.module.ts
文件
import { NgModule, NgModuleFactoryLoader, NO_ERRORS_SCHEMA } from "@angular/core";
import { NativeScriptModule } from "nativescript-angular/nativescript.module";
//Plugins
import { NSModuleFactoryLoader } from "nativescript-angular/router";
import { BarcodeScanner } from 'nativescript-barcodescanner';
import { TranslateModule, TranslateLoader } from '@ngx-translate/core';
import { TranslateHttpLoader } from '@ngx-translate/http-loader';
import { AppRoutingModule } from "./app-routing.module";
import { AppComponent } from "./app.component";
import { NativeScriptHttpModule } from "nativescript-angular/http";
import { HttpClientModule, HttpClient } from '@angular/common/http';
import * as platform from "platform";
declare var GMSServices: any;
if (platform.isIOS) {
GMSServices.provideAPIKey("XXX");
}
export function createTranslateLoader(http: HttpClient) {
return new TranslateHttpLoader(http, './assets/i18n/', '.json');
}
//Data service
// import { DataService } from './shared/dataService/dataService'
@NgModule({
bootstrap: [
AppComponent
],
imports: [
NativeScriptModule,
AppRoutingModule,
HttpClientModule,
NativeScriptHttpModule,
TranslateModule.forRoot({
loader: {
provide: TranslateLoader,
useFactory: (createTranslateLoader),
deps: [HttpClient]
}
})
],
declarations: [
AppComponent
],
providers: [BarcodeScanner,
{ provide: NgModuleFactoryLoader, useClass: NSModuleFactoryLoader }
],
schemas: [
NO_ERRORS_SCHEMA
]
})
export class AppModule { }
以及TranslateService文件
import {Component} from '@angular/core';
import {TranslateService} from '@ngx-translate/core';
@Component({
selector: 'app',
template: `
<div>{{ 'HELLO' | translate:param }}</div>
`
})
export class AppComponent {
param = {value: 'world'};
constructor(translate: TranslateService) {
// this language will be used as a fallback when a translation isn't found in the current language
translate.setDefaultLang('en');
// the lang to use, if the lang isn't available, it will use the current loader to get them
translate.use('en');
}
}
我在各个地方搜索,但是找不到基于@angular/common/http和ngx-translate以及NativeScriptHttpModule的Nativescript Angular 5应用程序的示例,能否有人帮助我,我真的很困惑,谢谢。