A Vue.js project 基于cli按个人需求进行优化,满足基本前端开发 简单实例 http://106.14.185.90/#/
.
├── mock ----------------------------- 本地mock配置文件
├── abc.json ------------------------- 项目构建配置文件
├── package.json --------------------- 项目配置
├── README.md ------------------------ 说明文件
├── build ---------------------------- 构建代码文件
├── config --------------------------- 构建配置文件
├── index.html ----------------------- 入口页面
└── src ------------------------------ 源码目录
├── assets ----------------------- 项目资源文件目录(图片、字体等)
├── components ------------------- 业务模块集合目录(组件)
├── fetch ------------------------ ajax请求管理文件
├── └── api -------------------- 请求配置 (axios ajax配置管理文件)
├── pages ------------------------ 页面集合目录
├── store ------------------------ vuex文件目录
├── App.vue ---------------------- vue公共配置文件
└── main.js ---------------------- 项目级入口配置文件
# 安装依赖
npm install
# 启动本地调试 localhost:8080
npm run dev
# 本地打包压缩
npm run build
# 本地打包压缩并查看项目
npm run build --report
# 生成page文件
npm run init page `name`
# 生成component文件
npm run init component `name`
本地代码想要访问测试环境接口可以通过以下配置
/config/index.js
dev: {
proxyTable: {
'/api': {
target: 'http://jsonplaceholder.typicode.com/',
changeOrigin: true,
pathRewrite: {'^/api': ''}
}
}
}
可以直接返回一段json例如
/mock/users/user.json
{
"code|1": [0, 0, 0, 0, 1],
"data": {
"list|10": [
{
"id|+1": 1,
"name": "@name",
"age|20-30": 1,
"email": "@email",
"date": "@date"
}
]
}
}
也可以写业务代码自定义返回参数
/mock/users/user.js
module.exports = function (req) {
var uid = req.query.uid;
if (!uid) {
return {
code: -1,
msg: 'no uid',
}
}
return {
code: 0,
data: {
"uid": +uid,
"name": "@name",
"age|20-30": 1,
"email": "@email",
"date": "@date",
},
};
};
引入以上配置在config/mock.js
文件中添加配置
module.exports = {
'GET::/api/1.json': 'mock::/users/list.json',
'GET::/test/2.json': 'mock::/users/user.js',
}
注:数据mock优先级低于反代理配置同父级,目录会被覆盖
页面统一在/src/pages
目录中添加
同事当项目无限大的时候通过router一次性加载全部的页面需要用户非常大耐心
所有我们在代码中统一使用router按需加载配置,在routes.js
添加page使用如下方式
{
path: '/hello',
component: function(resolve){
require(['./pages/Hello'], resolve);
}
}
命令生成page,routes会自动加入该配置
页面和组件分开目录编写有益于代码维护,自定义组件或业务公共模块统一在/src/components/
目录开发结构可与pages相同
- vue https://cn.vuejs.org/v2/api vue
- vuex https://vuex.vuejs.org/zh-cn/ vue状态管理框架
- vux https://vux.li/#/ vue样式库
- vue-router vue单页面开发框架
- axios
- less
项目已添加国际支持
详细情况 http://kazupon.github.io/vue-i18n/en/
src/styles/theme.less
@button-primary-bg-color: #ea2f2f;
@button-primary-active-bg-color: #da2f2f;
/src/App.vue
<transition name="move" >
<router-view></router-view>
</transition>
name值 fade bounce move