编写gulp脚本来复制功能相同内容不同的微信小程序

2017-09-28  本文已影响203人  球球ol

       最近公司开发小程序,为了占据市场,申请了十几个小程序,但是每次改一些bug什么的。。都要一次次打开每一个小程序,然后做相同的事情。。所以基于此,用gulp写了个脚本。。。修改其中一个小程序,然后可以直接同时生成你想要个数的不同内容的小程序。

       首先简单介绍下gulp

gulp是基于Nodejs的自动任务运行器, 她能自动化地完成 javascript/coffee/sass/less/html/image/css 等文件的的测试、检查、合并、压缩、格式化、浏览器自动刷新、部署文件生成,并监听文件在改动后重复指定的这些步骤。在实现上,她借鉴了Unix操作系统的管道(pipe)思想,前一级的输出,直接变成后一级的输入,使得在操作上非常简单。通过本文,我们将学习如何使用Gulp来改变开发流程,从而使开发更加快速高效。(http://www.ydcss.com/archives/18),gulp是基于node.js的库来进行文件操作的,所以得先装上node.js,然后大家根据这个网址来进行集成就好,重点说一下package.json,json文件不能有注释,并且大部分成熟这个文件除了必须设置的属性外,还需要有

"devDependencies": {

"gulp-imagemin":"^3.0.3",

},

这个属性,这个属性里面包含了你的脚本所用到的所有插件, "gulp-imagemin":"^3.0.3"   这是个例子

然后再创建一个gulpfile.js文件,这个文件里就是脚本执行的代码了,这个脚本的逻辑是这样的:1.删除指定文件夹下的所有文件(当初复制了多少个小程序就删除多少个文件夹下的文件)gulp.task('clean',del.bind(null,common.clean_dists))  2.将资源文件拷贝到指定文件夹下(n个小程序对应n个不同名称的文件夹)gulp.task('copy',function() {

returngulp.src(dirs+'/**/*')

.pipe(multiDest(common.copy_dists, {mode:'0755'}));

});

最后一步呢,就是把指定文件的字符串替换掉。

gulp.task('generate',next=>{

for(vari=0;i

generateConfig(i)//我把所有需要修改的信息都抽象到了一个js文件中,所以这个方法是修改config.js文件中的一些变量

generatejson(i)//因为我的小程序中app.json文件也需要修改,所以单另出一个方法修改它

}

})

这三步统一到一个方法中gulp.task('build', ['clean'],next=>runSequence('copy','generate','compile',next))

这些方法都写好后,直接打开终端cd到当前文件夹执行两个命令:npm install   然后再执行gulp build

之所以执行build,是因为在gulpfile.js中我指定了gulp.task('build', ['clean'],next=>runSequence('copy','generate','compile',next))这个方法叫build,并且打算拿这个方法作为js执行的入口,顺利的话执行完了,就创建好了对应个数的小程序,这些代码片段中出现的common是我抽象出来的一个js文件,专门放需要修改的数据数组

先写这么多吧,项目是公司的,所以源码不能公开,各位有什么不懂的我们可以一起讨论,这个东西入门比较麻烦,但是写好了还是很方便的,主要用到了一些gulp的插件和node.js的语法,我没有学过node.js所以这个是和同事一起完成的。

上一篇下一篇

猜你喜欢

热点阅读