整合开发 Angular2 + Bootstrap4 + Nodejs + Eclipse +Spring + SpringMVC +Mybatis

来源:互联网 发布:stl源码解析 编辑:程序博客网 时间:2024/06/06 07:30

我的其它博客将同步更新:CSDN、简书、github
标题看上去还是蛮吓人的,首先这不是标题党,也不是最终解决方案,用于项目需谨慎!

Angular2 中秋发布一来,有很多大神尝鲜,活跃在论坛上,但是基本都是前端开发的部分,很少或是没有找到于后端相关的。作为长期前后端一起做的苦逼程序员,没有前端妹子支持,只好多琢磨了。

一、先来看下我们的目标:

整合效果图 Angular2 + Bootstrap4 + Nodejs + Eclipse +Spring + SpringMVC +Mybatis
上图是我昨天给同事发的,描述了基本的结构。

二、环境准备:

开发工具:

1、Eclipse Neon Release (4.6.0)、及maven 等相关插件2、NodeJs、Git3、angular2-eclipse 插件4、联网

准备工作:
如果你想过整合上述关键词的话,我想你应该看过如下类似文章:
1、Angular2 eclipse中angular2开发环境的搭建
2、Angular 2 directives based on Bootstrap’s markup and CSS
3、SSM框架——详细整合教程(Spring+SpringMVC+MyBatis)
4、使用Mybatis-Generator自动生成Dao、Model、Mapping相关文件
在这里,我们的重点是Angluar2与JavaWeb,假设你都看过。
并且很幸运跑起来了。

补充下:《Angular2 eclipse中angular2开发环境的搭建》文中

//  执行命令时不要最后面的点“.”,且执行该命令之前你得先安装好Git、Python27,//  需要访问网络,而且各种慢//  注意是Python2.7版本,我安装过高版本不行...npm install -g angular-cli

三、整合:

现在你的后端开发是这样的:
SSM整合后端开发

前端开发的效果是这样的
image.png

创建一个项目真不容,网上下载慢,还要被墙,哎。。。

接下来就是我们正题了:
Angular1的时候Eclipse安装插件后,可以转成Angular项目,很可惜Angular2没有

选择java web项目右键 > configure > convent to angular project

  • 1、在Java web项目中新建文件夹web
  • 2、拷贝project_angular项目中文件到JavaWeb项目得web目录中(.project 可以不需要)
  • 3、在java web项目中映射angular项目dist文件夹
选择java web项目右键 > Properties > Deployment AssemblyAnd > Folder > 选择 web/dist > ok

在java web项目中映射angular项目dist文件夹

!And > Folder > 选择 web/dist > ok

其实最主要得就是这一步,这样angular2 编译后得文件在dist里面,添加映射后,Java web Run As Server 时会把dist里面得文件放到与src/main/webapp/编译后相同的地方,也就是web根目录,优先级是后面的,也就是dist。

  • 4、这样你就可以run javaweb项目了,但是,出来的首页会一直显示加载中(是不是很着急)。
  • 5、经过调试,你不难发现在运行javaweb时反问路径时这样的:
http://localhost:8080/ovit-java-framework/

而angular路径是这样的

http://localhost:4200/

不一样的是有一个以项目命名的虚拟路径,所以我们得更改web/dist/index.html 的base

<!-- web/dist/index.html --!><!doctype html><html><head>  <meta charset="utf-8">  <title>ProjectAngularTest</title><!-- 这里加上你项目名称 --!>  <base href="/ovit-java-framework/">  <!-- <base href="/"> -->  <meta name="viewport" content="width=device-width, initial-scale=1">  <link rel="icon" type="image/x-icon" href="favicon.ico">   <link rel="stylesheet" href="res/css/bootstrap.min.css"> </head><body>  <app-root>加载中...</app-root><script type="text/javascript" src="inline.js"></script><script type="text/javascript" src="styles.bundle.js"></script><script type="text/javascript" src="main.bundle.js"></script></body></html>
  • 6、重新run as server 你的java web项目,是不是跑起了!!!
让我们整理下思路,回顾下开发过程
  • 1、修改了后端代码:
    项目 > 右键 > Run As Server
  • 2、修改了前端代码:
    1)、在web/目录所在的物理路径执行ng build
    D:\Work\BSI\Code\ovit-java-framework\web>ng build
    2)、修改web/dist/index.html文件中的path
    3)、项目 > 右键 > Run As Server

总结

其实这`(是)`算`(不)`不`(是)`上`(有)`是`(扁)`项`(我)`目`(的)`整`(冲)`合`(动)`,很牵强。
弊端,或者说有还没配合好的地方
  • 1、新建的angular2 项目 > 右键 > Run As 选项中有 ng build、ng server、npm intall、npm update等快捷运行的功能,整合后都没有了,残存的 npm intall、npm update 也没有反应,应该是与.project文件有关。
  • 2、开发非常不方便:修改前端的*.ts 等文件后运行起了比较麻烦,且跟eclipse毛关系都没有,所以你的前端还是可以选项你自己的工具,比如subline等。
    但总的来说 Angular2与JavaWeb在一起了,如果各位有更好的方法,我只想对你说“老司机,带带我!!!”

作为一个比较懒程序员,我总是先加入一些自动生成代码、通用服务的功能能,以保证做大量重复的业务的编码时偷懒,从而形成我的懒人开发模式 ^-^。

0 0