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

       最近公司开发小程序,为了占据市场,申请了十几个小程序,但是每次改一些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所以这个是和同事一起完成的。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 前言 本文默认你已经安装好node环境,并且熟悉node命令,和window cd命令。 gulp简介 基于nod...
    9I阅读 5,979评论 4 50
  • 在现在的前端开发中,前后端分离、模块化开发、版本控制、文件合并与压缩、mock数据等等一些原本后端的思想开始...
    Charlot阅读 10,858评论 1 32
  • 安装Gulp首先需要安装Node.js,并在控制台输入$ npm install gulp -gMac端需要写成$...
    LaBaby_阅读 4,509评论 0 1
  • 对网站资源进行优化,并使用不同浏览器测试并不是网站设计过程中最有意思的部分,但是这个过程中的很多重复的任务能够使用...
    懵逼js阅读 4,724评论 0 8
  • 编辑于2015年 转载自某作者的译文 作者要是看到请联系我注明出处 对网站资源进行优化,并使用不同浏览器测试并不是...
    krock01阅读 3,222评论 0 2

友情链接更多精彩内容