我对angular并不陌生,并开始从tutorial开始学习angular5。
现在我正在将普通的HTML模板转换为Angular 5版本,将外部JS文件添加到angular 5 项目时遇到了困难。
有人可以帮助我将外部js文件添加到angular5项目吗?
这是我更新的angular.json文件。仍然不能为我工作。
/*angular.json*/
{
"$schema": "./node_modules/@angular/cli/lib/config/schema.json",
"version": 1,
"newProjectRoot": "projects",
"projects": {
"minimus-master": {
"root": "",
"sourceRoot": "src",
"projectType": "application",
"prefix": "app",
"schematics": {},
"architect": {
"build": {
"builder": "@angular-devkit/build-angular:browser",
"options": {
"outputPath": "dist/minimus-master",
"index": "src/index.html",
"main": "src/main.ts",
"polyfills": "src/polyfills.ts",
"tsConfig": "src/tsconfig.app.json",
"assets": [
"src/favicon.ico",
"src/assets"
],
"styles": [
"src/styles.css"
],
"scripts": [
"src/assets/vendors/jquery/jquery.min.js",
"src/assets/vendors/imagesloaded/imagesloaded.pkgd.js",
"src/assets/vendors/isotope-layout/isotope.pkgd.js",
"src/assets/vendors/jquery-one-page/jquery.nav.min.js",
"src/assets/vendors/jquery.easing/jquery.easing.min.js",
"src/assets/vendors/jquery.matchHeight/jquery.matchHeight.min.js",
"src/assets/vendors/magnific-popup/jquery.magnific-popup.min.js",
"src/assets/vendors/masonry-layout/masonry.pkgd.js",
"src/assets/vendors/jquery.waypoints/jquery.waypoints.min.js",
"src/assets/vendors/swiper/swiper.jquery.js",
"src/assets/vendors/menu/menu.js",
"src/assets/vendors/typed/typed.min.js",
"src/assets/js/main.js"
]
},
"configurations": {
"production": {
"fileReplacements": [
{
"replace": "src/environments/environment.ts",
"with": "src/environments/environment.prod.ts"
}
],
"optimization": true,
"outputHashing": "all",
"sourceMap": false,
"extractCss": true,
"namedChunks": false,
"aot": true,
"extractLicenses": true,
"vendorChunk": false,
"buildOptimizer": true
}
}
},
"serve": {
"builder": "@angular-devkit/build-angular:dev-server",
"options": {
"browserTarget": "minimus-master:build"
},
"configurations": {
"production": {
"browserTarget": "minimus-master:build:production"
}
}
},
"extract-i18n": {
"builder": "@angular-devkit/build-angular:extract-i18n",
"options": {
"browserTarget": "minimus-master:build"
}
},
"test": {
"builder": "@angular-devkit/build-angular:karma",
"options": {
"main": "src/test.ts",
"polyfills": "src/polyfills.ts",
"tsConfig": "src/tsconfig.spec.json",
"karmaConfig": "src/karma.conf.js",
"styles": [
"src/styles.css"
],
"scripts": [],
"assets": [
"src/favicon.ico",
"src/assets"
]
}
},
"lint": {
"builder": "@angular-devkit/build-angular:tslint",
"options": {
"tsConfig": [
"src/tsconfig.app.json",
"src/tsconfig.spec.json"
],
"exclude": [
"**/node_modules/**"
]
}
}
}
},
"minimus-master-e2e": {
"root": "e2e/",
"projectType": "application",
"architect": {
"e2e": {
"builder": "@angular-devkit/build-angular:protractor",
"options": {
"protractorConfig": "e2e/protractor.conf.js",
"devServerTarget": "minimus-master:serve"
},
"configurations": {
"production": {
"devServerTarget": "minimus-master:serve:production"
}
}
},
"lint": {
"builder": "@angular-devkit/build-angular:tslint",
"options": {
"tsConfig": "e2e/tsconfig.e2e.json",
"exclude": [
"**/node_modules/**"
]
}
}
}
}
},
"defaultProject": "minimus-master"
}
答案 0 :(得分:3)
您可以通过scripts
将Javascript文件添加到全局范围
angular.json
中项目的构建目标选项中的option选项。
这些文件的加载方式与您在<script>
中添加它们的方式完全相同
标记在index.html中。
<script src="path to your js file"></script>
或
您可以指定要包含在构建中的全局脚本,它可以在您的角度项目的 angular.json文件脚本数组中
(如果您的角度版本为<6.0,则为angular-cli.json文件)。
{
"scripts": [
// path to your js file
]
}
有关更多信息,请参见this文章。
答案 1 :(得分:0)
您将编辑angular-cli.json
的脚本部分并添加文件
"scripts": [
"<path to your js file>",
]