用vue快速开发app的脚手架工具
前言
多页面应用于结构较于简单的页面,因为简答的页面使用router又过于麻烦.本脚手架出于这样的场景被开发出来.
使用脚手架搭配hbuilder也同样可以快速使用vue开发安卓和ios app.
本文最大特点:
- webpack4
- 多页面
- 跨域proxy代理
- vconsole移动端调试,手机上的开发者工具
- es6/es7 babel 转换
项目地址 github
使用手册
mogoh5+ 是一个 vue 多页面 脚手架工具 ,结合 h5+可以快速开发安卓与苹果 app.
即使不适用 hbuilder 打包成 app,本脚手架同样可以作为多页面网页生成的参考项目.
特性
- 支持 npm 生态
- 支持 vue 语法,以及 vue 生态,比如 vux,mint,vant
- 支持 es6/es7 语法
- 使用 vconsole 调试
- vscode 友好
- 局域网便捷调试
- 兼容部分 mui 语法
这些特性其实不是什么新鲜特性,只是单独在 hbuilder 无法使用.
快速上手
直接下载项目然后根据需求定制打包,最后通过 hbuilder 云打包即可生成 app.
本文自带一个案例是使用 vantui 开发的几个界面,如果你喜欢其他 ui 同样可以替换成其他的 ui.
// 1.安装模块 npm i // or yarn // 2.调试 npm start // 将manifest.json 的`页面入口` 修改成 http://your_ip:8082/ // 3.打包 npm run build
使用
主要怎么使用 mogoh5+做正式的开发,在开发过程中一定要遵守 目录规则 ,否则会有意想不到的错误.
目录结构
. ├── docs // 文档 ├── index.html // 入口模板 ├── jsconfig.json //js配置 ├── manifest.json //hbuilder 入口文件 ├── src │ ├── components //组件文件夹 │ │ └── list.vue //组件 │ ├── index.js //主页入口文件 │ ├── index.vue // 主页vue文件 │ ├── page // 页面 │ └── utils // 工具 ├── unpackage // hbuilder 构建目录 │ └── res └── webpack.config.js //webpack配置目录
新建页面
假如我们要新建一个名称为 list 的页面作为商品列表,我们就要在 ./src/page/goods 下新建 list.js 和 list.vue 两个文件. list.js 作为多页面的入口, list.vue ,脚手架自带了几个页面可供参考.
遵循相对路径原则,如果在 src 访问这个页面则就是 ./goods/list.html !!! 后缀一定是 .html
新建组件
组件放入 ./src/components 目录下,如果组件较多,可自行建立目录.比如 demo 中使用的 logo 组件可以作为参考.
新建工具库
工具库 ./src/utils 主要放一些公用函数,比如请求,打开 webview,支付,分享等执行函数. demo 中封装了部分来自 mui 的函数比如 自定义事件 , webview .这些函数可以作为参考.
common.js` 是每个页面都需要加载的一个 js,里面加载了`fastclick`和`vconsole`.如果全局需要加统计,全局执行的函数,可以放在这个文件里面.
`./src/utils` 做了 `alias`别名,可以 直接这样加载 `import common from "utils/common"`.
发送请求
请求库
demo 的请求使用的是 axios ,同样你喜欢什么库都可以自己去封装.
常见的请求库有 fetch , request , superagent , jquery-ajax .
跨域
由于 npm start 后,调试网页是挂在局域网上,并且作为 hbuilder 的 页面入口 ,因此,在请求时会出现 跨域 .
在 ./build.js 中使用本地代理,将下面的 https://api.douban.com 修改成自己使用的业务域名即可.
proxy: { "/api": { name:"doubanapi", // 自己取名 target: "https://api.douban.com", pathrewrite: { "^/api": "" }, changeorigin: true, secure: false }, "/baidu_api": { name:"baiduapi", // 自己取名 target: "https://api.baidu.com", pathrewrite: { "^/api": "" }, changeorigin: true, secure: false }, ... }
如果有更多业务域名可以继续在 proxy 添加.
只有开发的时候才会有跨域问题,打包后的文件网址会被替换成被代理的网址,因此发送请求一定要加上名称 doubanapi
request({ url: doubanapi + "/booklist" });
调试
在 hbuilder 中调试会有诸多问题,比如:
- 不能直接打印 数组 , 对象 ,需要转成字符串.
- 即使使用 webview调试 ,仍然不能打印出数组,在 mac 上使用也非常不方便.
使用 vconsole ,调试的问题基本就脱离 hbuilder 了,使用 vconsole 主要优点如下
- 可以打印数组,对象
- 可以查看请求,cookie,localstorage
- 在system栏目中可以看到页面加载速度
- 可以查看元素
基本上就是一个简化的 开发者工具栏 ,对于调试来说非常简便了.
打包
npm run build
运行命令后会有一个 dist 目录,里面的经过压缩的静态文件.
hbuilder 发行打包
在使用 hbuilder 制作安装包前,请将 入口文件 修改成 dist/index.html . 然后可以安心的打包了.
兼容 mui.js
对于兼容 mui 部分函数的问题,已经在移植部分函数到utils中,在未来的更新中会慢慢移植.
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
上一篇: 更改RubyGem安装源
下一篇: 爆笑趣事图片:都是发生在身边的真人真事