博客
关于我
Vue——进阶篇
阅读量:364 次
发布时间:2019-03-04

本文共 2546 字,大约阅读时间需要 8 分钟。

Vue之进阶篇

author:木子六日

学习视频来源于

文章目录

1. 环境

在开始开发前需要先搭建好开发环境。首先确保Node.js已安装。建议修改镜像地址为淘宝镜像源,以加快包裹下载速度。接着安装必要的开发工具:

  • 安装Webpack:npm install webpack -g
  • 安装Vue CLI:npm install vue-cli -g
  • 创建项目:vue create 项目名(选择router、Vuex和Babel插件,建议不选择ESLint以减少配置复杂度)
  • 可视化界面管理项目:vue ui
  • 项目部署:npm run build后将dist目录上传至服务器

2. Router

在单页面应用中,路由配置是必不可少的。确保在项目创建时选择了Router插件。

路由配置文件位于src/router/index.js。以下是一个典型的路由配置示例:

import Vue from 'vue'  import VueRouter from 'vue-router'  import Test1 from '../views/test1.vue'  import Test2 from '../views/test2.vue'  Vue.use(VueRouter)  const routes = [    { path: '/', redirect: '/test1' },    { path: '/test1', component: Test1 },    {      path: '/test2',      component: Test2,      children: [        { path: '', redirect: 'news' },        { path: 'news', component: () => import('../components/Test2News.vue') },        { path: 'sports', component: () => import('../components/Test2Sports.vue') }      ]    },    {      path: '/test3/:id',      component: () => import('../views/test3.vue')    },    { path: '/profile', component: () => import('../components/Profile.vue') }  ]  const router = new VueRouter({    routes  })

在组件中使用Router时,可以使用以下标签:

测试1      测试2      测试3      档案

对应的组件文件如下:

3. Vuex

Vuex用于集中管理组件状态,提供一个公共的数据池。确保在项目创建时选择了Vuex插件。

状态管理文件位于src/store/index.js。以下是一个简要的Vuex配置示例:

import Vue from 'vue'  import Vuex from 'vuex'  Vue.use(Vuex)  export default new Vuex.Store({    state: {      counter: 0    },    mutations: {      increment(state) {        state.counter++      },      decrement(state) {        state.counter--      },      incrementCount(state, count) {        state.counter += count      }    },    actions: {      aIncrement(context) {        setTimeout(() => {          context.commit('increment')        }, 1000)      }    }  })

在组件中使用Vuex状态:

{{ $store.state.counter }}       +      -      +5

建议安装Vue DevTools来更方便地调试Vuex状态。

4. Axios

Axios是Vue推荐的AJAX库,简洁易用,支持浏览器和Node.js环境。

安装命令:npm install axios --save

import axios from 'axios'  import App from './App.vue'  import router from './router'  import store from './store'  new Vue({    router,    store,    render: h => h(App)  }).$mount('#app')

Axios的使用示例:

axios({    url: 'http://123.207.32.32:8000/home/multidata'  }).then(res => {    console.log(res)  })

可根据需求配置全局参数:

axios.defaults.baseURL = 'http://123.207.32.32:8000'  axios.defaults.timeout = 2000

建议对Axios进行封装,便于维护:

export function request(config) {    return axios.create({      baseURL: 'http://123.207.32.32:8000'    }).call(config)  }

5. 其他工具

  • 建议使用Webpack或直接配置Webpack进行项目开发
  • Element UI是一个与Vue风格匹配的UI框架

转载地址:http://izee.baihongyu.com/

你可能感兴趣的文章
Openlayers高级交互(11/20):显示带箭头的线段轨迹,箭头居中
查看>>
Openlayers高级交互(12/20):利用高德逆地理编码,点击位置,显示坐标和地址
查看>>
Openlayers高级交互(13/20):选择左右两部分的地图内容,横向卷帘
查看>>
Openlayers高级交互(14/20):汽车移动轨迹动画(开始、暂停、结束)
查看>>
Openlayers高级交互(15/20):显示海量多边形,10ms加载完成
查看>>
Openlayers高级交互(16/20):两个多边形的交集、差集、并集处理
查看>>
Openlayers高级交互(17/20):通过坐标显示多边形,计算出最大幅宽
查看>>
Openlayers高级交互(18/20):根据feature,将图形适配到最可视化窗口
查看>>
Openlayers高级交互(19/20): 地图上点击某处,列表中显示对应位置
查看>>
Openlayers高级交互(2/20):清除所有图层的有效方法
查看>>
Openlayers高级交互(20/20):超级数据聚合,页面不再混乱
查看>>
Openlayers高级交互(3/20):动态添加 layer 到 layerGroup,并动态删除
查看>>
Openlayers高级交互(4/20):手绘多边形,导出KML文件,可以自定义name和style
查看>>
Openlayers高级交互(5/20):右键点击,获取该点下多个图层的feature信息
查看>>
Openlayers高级交互(6/20):绘制某点,判断它是否在一个电子围栏内
查看>>
Openlayers高级交互(7/20):点击某点弹出窗口,自动播放视频
查看>>
Openlayers高级交互(8/20):选取feature,平移feature
查看>>
Openlayers高级交互(9/20):编辑图形(放缩、平移、变形、旋转),停止编辑
查看>>
Openlayers:DMS-DD坐标形式互相转换
查看>>
openlayers:圆孔相机根据卫星经度、纬度、高度、半径比例推算绘制地面的拍摄的区域
查看>>