zoukankan      html  css  js  c++  java
  • vue全家桶

    Vue两大核心思想:组件化数据驱动

    组件化:把整体拆分为各个可以复用的个体;数据驱动:通过数据变化直接影响bom展示,避免dom操作。

    Vue全家桶系列,包含了vue-router(http://router.vuejs.org),vuex(http://vuex.vuejs.org), vue-resource(https://github.com/pagekit/vue-resource)。再加上构建工具vue-cli,sass样式,就是一个完整的vue项目的核心构成。

    一、Vue-cli是快速构建这个单页应用的脚手架,

    # 全局安装 vue-cli
    $ npm install --global vue-cli
    # 创建一个基于 webpack 模板的新项目
    $ vue init webpack my-project
    $ cd my-project
    $ npm install
    $ npm run dev


    二、vue-router

    安装:

    npm install vue-router

    在main.js文件中,

    import Vue from 'vue'
    import VueRouter from 'vue-router'
    
    Vue.use(VueRouter)

    三、vuex

    vuex为专门为vue.js应用程序开发的状态管理,可以理解为全局的数据管理。

    vuex主要五部分组成:state、getters、action、mutation、modules组成。

    import Vuex from vuex
    
    Vue.use(Vuex)
    new Vue({
      el: '#app',
      router,
      store,
      components: { Layout },
      template: '<Layout/>'
     })

     1.state

     类似vue 对象的data, 用来存放数据以及状态。存放的数据为响应式,如果数据改变,那么依赖数据的组件也会发生相应的改变。

    可以通过辅助函数mapState把全局的state和getters映射到当前组件的computed计算属性中。

     

    computed: {
        count () {
          return this.$store.state.count
        }
      }

     

    
    
    import { mapState } from 'vuex'

    computed: { localComputed () { /* ... */ }, // mix this into the outer object with the object spread operator ...mapState({ // ... })
      ...mapState([
      // map this.count to store.state.count
      'count'
      ])
    }
     

     

     

    2、getters

    Getters will 接收state作为第一个参数。

     

    const store = new Vuex.Store({
      state: {
        todos: [
          { id: 1, text: '...', done: true },
          { id: 2, text: '...', done: false }
        ]
      },
      getters: {
        doneTodos: state => {
          return state.todos.filter(todo => todo.done)
        }
      }
    })

     

    也可以接收其他getters作为第二个参数

    getters: {
      // ...
      doneTodosCount: (state, getters) => {
        return getters.doneTodos.length
      }
    }

    调用getter:

    computed: {
      doneTodosCount () {
        return this.$store.getters.doneTodosCount
      }
    }

    通过辅助函数mapGetters将store getters映射到当前组件的computed计算属性中。

    import { mapGetters } from 'vuex'
    
    export default {
      // ...
      computed: {
        // mix the getters into computed with object spread operator
        ...mapGetters([
          'doneTodosCount',
          'anotherGetter',
          // ...
        ])
      }
    }

    或者另起名字;

    ...mapGetters({
      // map `this.doneCount` to `this.$store.getters.doneTodosCount`
      doneCount: 'doneTodosCount'
    })

     

    3mutation (mutation只支持操作同步)

     

    每个 mutation 都有一个字符串的 事件类型(type) 一个 回调函数(handler)。这个回调函数就是我们实际进行状态更改的地方,并且它会接受 state 作为第一个参数。

     

    mutations: {
      increment (state, payload) {
        state.count += payload.amount  
      }
    }

     

    store.commit('increment', {
      amount: 10
    })

    可以通过辅助函数mapMutations把全局的mutation映射到当前组件的methods中

    import { mapMutations } from 'vuex'
    
    export default {
      // ...
      methods: {
        ...mapMutations([
          'increment', // map `this.increment()` to `this.$store.commit('increment')`
    
          // `mapMutations` also supports payloads:
          'incrementBy' // map `this.incrementBy(amount)` to `this.$store.commit('incrementBy', amount)`
        ]),
        ...mapMutations({
          add: 'increment' // map `this.add()` to `this.$store.commit('increment')`
        })
      }
    }

     

    2actions

    action支持异步调用(可以调用api),mutation只支持操作同步,并且action提交的是 mutation,而不是直接变更状态。

     

    const store = new Vuex.Store({
      state: {
        count: 0
      },
      mutations: {
        increment (state) {
          state.count++
        }
      },
      actions: {
        increment (context) {
          context.commit('increment')
        }
      }
    })

     

    或通过参数解构:

    actions: {
      increment ({ commit }) {
        commit('increment')
      }
    }

    Action 通过 store.dispatch 方法触发。

    可以通过辅助函数mapActions把全局的action映射到当前组件的methods中

     

    store.dispatch('increment')
    import { mapActions } from 'vuex' 
    methods: { ...mapActions([
    'increment', // map `this.increment()` to `this.$store.dispatch('increment')` // `mapActions` also supports payloads: 'incrementBy' // map `this.incrementBy(amount)` to `this.$store.dispatch('incrementBy', amount)` ]), ...mapActions({ add: 'increment' // map `this.add()` to `this.$store.dispatch('increment')` }) }

    四、vue-rource

    见前后端数据通讯篇

     

  • 相关阅读:
    web设计经验<一> 提升移动设备响应式设计的8个建议
    web设计经验<九>教你测试手机网页的5大方法
    HTML5吧!少年
    用java页面下载图片
    在springmvc中,获取Connection接口
    360记住用户信息
    360浏览器Uncaught TypeError: object is not a function问题
    validation插件
    上传附件验证方法
    瀑布流布局
  • 原文地址:https://www.cnblogs.com/ceceliahappycoding/p/vue.html
Copyright © 2011-2022 走看看