详解Angular

网友投稿 208 2023-05-13


详解Angular

最近在学习angular(Angularjs 2),根据教程使用angular-cli新建项目,然而在添加jquery和Bootstrap第三方库时遇到了问题...

初试

我最初的想法是直接将相对路径写到index.html即可,如下:

然鹅。。。并不好使,浏览器抓包会显示请求

http://localhost:4200/node_modules/juqery/dist/jquery.min.js返回404错误,bootstrap也是相同的问题,这里显然是路径不正确,我的项目目录结构如下:

angular-form/

|- src/

| |- app/

| |- index.html

| ...

|- node_modules

| |- jquery/

| |- bootstrap/

| ...

其中,网站运行时的根目录是src目录,

所以获取不到与其处在同一目录的node_modules目录下文件也在情理之中...

另辟蹊径

经过乱七八糟的查找...发现了可以在/.angular-cli.json文件中配置脚本引用,

在其app.scripts下配置要添加的脚本, 并在app.styles下配置要添加的样式文件:

"app": [

{

...

"styles": [

"node_modules/bootstrap/dist/css/bootstrap.min.css"

],

"scripts": [

"nodhttp://e_modules/bootstrap/dist/css/bootstrap.min.css",

"node_modules/bootstrap/dist/css/bootstrap.min.css"

],

...

}

]

再次启动网站,却连编译都无法通过...出现如下问题:

ERROR in multi script-loader!./src/~/jquery/dist/jquery.min.js script-loader!./src/~/bootstrap/dist/js/bootstrap.min.js

Module not found: Error: Can't http://resolve 'E:\Code\JavaScript\angular2\angular-forms\src\node_modules\jquery\dist\jquery.min.js' in 'E:\Code\http://JavaScript\angular2\angular-forms'

@ multi script-loader!./src/~/jquery/dist/jquery.min.js script-loader!./src/~/bootstrap/dist/js/bootstrap.min.js

可以看出这里去加载js脚本时寻找的是src/目录下的node_modules目录, 所以加载失败。这意味着angular-cli.json文件中配置的路径时相对于网站根目录的路径, 接着做如下更改:

"app": [

{

...

"styles": [

"../node_modules/bootstrap/dist/css/bootstrap.min.css"

],

"scripts": [

"../node_modules/bootstrap/dist/css/bootstrap.min.css",

"../node_modules/bootstrap/dist/css/bootstrap.min.css"

],

...

}

]

再次运行网站,成功加载~~~

回看来时路

后来了解到,angular-cli的项目使用webpack来将模块打包, 我们这里配置的scripts和styles会被打包成scripts.bundle.js 和styles.bundle.js文件加载到前台页面,而后就可以正常使用这些第三方库了~~~


版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:关于RxJava的一些特殊用法小结
下一篇:Angular2使用Angular CLI快速搭建工程(一)
相关文章

 发表评论

暂时没有评论,来抢沙发吧~