设为首页 收藏本站
查看: 1462|回复: 0

[经验分享] gulp+webpack+react工程学习

[复制链接]

尚未签到

发表于 2017-3-3 06:27:40 | 显示全部楼层 |阅读模式
  现在项目开发环境是gulp + webpack + react。几个需求下来,做业务逻辑比较熟练,但是对于项目目录中的一些文件,并不了解他们的意义和用途,也不是很清楚整个项目启动、运行、打包、发布的过程中每一步的输入和输出以及起作用的工具。借这篇博客散碎更新学习细节,以免变成:一不小心把环境配置好后就只会写业务的程序员。
  项目目前使用到的框架包括:node, gulp, webpack, react, sass, ruby, compass, freemarker, jdk, mvn, jetty,当然通过git做版本控制。  
  目录结构如下图所示:
   DSC0000.png
  1. shark-deploy-conf.json是gulp中使用的打包工具shark-deploy-git的配置文件。shark-deploy-git是这样被使用的(部署测试环境为例, 省略部分代码):



var deployGit = require('shark-deploy-git');
gulp.task('deploy', function(cb) {
var options = {
       branch: argv.branch,
build: 'build/app',
deploy: '/home/aaa/deploy/XXX/deploy/XXX/test',
repo: 'http://account:password@git.internal/xxx/xxxx.git'
  }
deployGit(options);
var staticOptions = {
        branch: argv.branch,
build: 'build/static',
deploy: '/home/aaa/deploy/pages',
     repo: 'http://account:password@git.internal/xxx/xxxx-static.git'
  };
deployGit(staticOptions);
});
  2. config.rb是compass配置文件,compass是sass的工具库,在sass基础上封装了模块和组件,类似js与jquery的关系(来自阮一峰博客)。compass是用ruby开发的,所以开发环境需安装ruby.
  compass是这样用的:



gulp.task('compass', function(cb) {
execCmd(['compass', 'clean']);
execCmd(['compass', 'compile']);
cb();
});
  execCmd方法是对系统命令的执行,执行命令需要node的sync-exec库。compass跟node并没有什么关系。
  3. Webpack是模块加载器+打包工具。可以直接用require的形式引入各个模块,包括less,jsx等。Webpack会为我们编译这些模块,然后require。编码时所有的js或jsx文件以commonJS规范的模块存在,而程序员只需要写回调里面的内容,webpack会帮助我们添加。保留define也可以,webpack支持旧模块迁移。可通过npm install安装。
  webpack在gulpfile中被使用,使用方法是这样的:



var webpack = require('gulp-webpack');
gulp.task('webpack-serve', function() {
return gulp.src('')
.pipe(webpack(webpackConfig('serve')))
.pipe(gulp.dest(path.join(webappDir, jsPath, 'dist')));
});
gulp.task('webpack-server', function() {
return gulp.src('')
.pipe(webpack(webpackConfig('server') ))
.pipe(gulp.dest(path.join(tmp1, 'js/dist')));
});

  webpack可以把src下的源文件打包到dist目录下,通过配置webpack.config.js, 常用配置参数见https://www.npmjs.com/package/gulp-webpack
  对于react来说,需要编译jsx, 需要npm install babel-loader --save-dev, 使用的时候在webpack.config.js中设置:



loaders: [{
test: /\.jsx?$/,
exclude: /(node_modules|bower_components)/,
loaders: ['babel?presets[]=react&cacheDirectory']
}],
  4. gitignore是git提交时不需要提交的文件列表
  5. deploy-online.sh, deploy-test.sh是打包所使用的shell脚本。切到需要部署的分支之后执行gulp build和gulp deploy.
  gulp build过程是
  clean: 清空build目录
  build-java:执行mvn complile
  'compass-server': 执行compass clean与compass compile
  'webpack-server': webpack将jsx编译为js,从src到dist
  'useref-ftl', 'user-html': 1)ftl文件:根据注释将js与css文件合并 2)对于angular工程,添加注入依赖的代码,以免文件压缩后依赖名被改写导致注入失败。3)gulp uglify: 压缩js; 4)gulp-autoperfixer: css浏览器前缀自动添加; 5)minifyCSS: 合并压缩css文件;6)目标输出到文件夹temp1
  
   'imagemin': 图片目录下图片文件压缩
        'revision-image': 图片加版本号。gulp-rev的功能是给文件名加md5后缀(rev()),维护一个保存实际文件路径与md5文件名的json(manifest), 并将html中对该文件的引用也添加md5(rev-replace). 新版本更新,旧版本不删除,回滚时不重新请求文件。
        ['revreplace-css', 'revreplace-js']:为css与js中的图片路径加hash['revision-css', 'revision-js']: 为css与js文件加版本号['revreplace-html', 'revreplace-ftl']: 为html与ftl中的css与js路径加hash['copy-build', 'copy-build-java']:
  copy-build-java: 将src web-inf下的文件拷贝到build web-inf下
  copy-build: src和tmp2下各种文件拷贝到build
  6..sass-cache目录: sass用来缓存部分已经编译的模板或者模块,用来加快再次编译的速度
  7. build目录:打包目录。明明不用提交布吉岛为何本地还有=。=
  8. lib目录:存放java依赖包
  9. node_modules: node模块存放
  10. src目录:
  main: 源文件目录。webapp:前端代码(scss, img, js, ftl) java:后端代码 resources: dev&test&online各种环境的properties配置文件
  test: mock数据用的目录。
  11. 前端本地调试使用的gulp serve: 1) 启动express. 设置mock数据的目录, 设置livereload 2)watch ftl html css js 3)webpack serve
  

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-349370-1-1.html 上篇帖子: java web应用开发简单梳理(mybatisl+springMvc+tomcat) 下篇帖子: Spring4.0系列9-websocket简单应用
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表