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

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

作者: 球球ol | 来源:发表于2017-09-28 16:37 被阅读203次

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

    相关文章

      网友评论

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

          本文链接:https://www.haomeiwen.com/subject/yopldttx.html