我是angular的新手,从这个tutorial开始学习angular5。
我正在将普通的超文本标记语言模板转换为Angular5版本,现在我在向angular5项目添加外部JS文件时遇到了困难。
我在angular.json文件中包含了angular项目中的Javascript文件,但我的javascript文件似乎无法工作。
有人能帮上忙吗?我在main.js文件上编写自定义jquery代码,这样做正确吗?
我的意思是,现在在jQuery代码方面工作,参见下面的示例代码。
/**
* Typing effect Not working
*/
jQuery('.typing__module').each(function (index) {
var self = jQuery(this),
_wrapper = jQuery('.typed', self)[0],
optData = eval('(' + self.attr('data-options') + ')'),
optDefault = {
stringsElement: self.find('.typed-strings')[0],
typeSpeed: 50,
backSpeed: 500,
fadeOut: true,
loop: true
},
options = jQuery.extend(optDefault, optData);
var typed = new Typed(_wrapper, options);
});
/*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"
}
发布于 2018-07-06 21:13:56
声明Jquery,
import * as $ from 'jquery';
还会导入类型化的import * as Typed from 'typed.js'
如果它们是通过npm或yarn安装的,那么您不需要添加到angular.json就可以了。
然后,您应该能够正确地引用两者,而不会出现任何错误。
发布于 2019-06-10 18:20:43
你可以通过Angular在所有编译过的js文件的末尾加载html模板main.js即src/assets/js/main.js
<html>
<head>
</head>
<body>
<div>
<!--All Code here-->
</div>
<script src="~/dist/Infotech/runtime.js"></script>
<script src="~/dist/Infotech/polyfills.js"></script>
<script src="~/dist/Infotech/styles.js"></script>
<script src="~/dist/Infotech/vendor.js"></script>
<script src="~/dist/Infotech/main.js"></script>
**<script src="~/src/assets/js/main.js"></script>**
</body>
</body>
</html>
希望这能有所帮助:)
https://stackoverflow.com/questions/51209209
复制相似问题