简单使用Vuex步骤及注意事项

摘要:
使用Vuex的步骤:(1)安装:1.使用npm安装:npminstallvuex--save2.使用script标签引入如果使用第一种方式安装Vuex插件,在

使用Vuex的步骤:

(1)安装:

1.使用npm安装:

npm install vuex  --save

2.使用script标签引入

<script src="http://t.zoukankan.com/path/to/vue.js"></script>

<script src="http://t.zoukankan.com/path/to/vuex.js"></script>

如果使用第一种方式安装Vuex插件,在使用Vuex插件之前需要在main.js入口文件中

1‘ 使用import方式引入Vuex

import Vuex from ‘vuex’

2‘ 使用Vue的插件引入函数Vue.use()使用Vuex

Vue.use(Vuex);

(2)安装之后可以通过Vuex实例对象的Store方法创建一个store对象:

var store = newVuex.Store({
    state:{
        NewMsg:{
            Msgs:[
                {
                    title:'暂无消息',
                    content:'暂无消息!',
                    url:'#no_msg',
                    id:'no_msg'}
            ]
        },
    },
    mutations:{
        modifyMsg (state,Obj){
            if(state.NewMsg.Msgs[0].id === 'no_msg'){
                state.NewMsg.Msgs.shift();
            }
            var obj ={
                title:Obj.title,
                content:Obj.content
            };
            obj.id = 'Msg_' +Obj.id;
            obj.url = '#' +obj.id;
            state.NewMsg.Msgs.push(obj);
        }
    },
    actions:{
        fetchMsg (context){
            $.ajax({
                    url:'PHP/GetMsgs.php',
                    type:'GET',
                    data:{},
                    dataType:'json',

                    success:function(response){
                        if ( typeof response === 'string') {
                            response =JSON.parse(response);
                        }
                        console.log(response);
                        $(response).each(function(k,v){
                            //console.log(v.id+v.title+v.content);
                            context.commit('modifyMsg',v);
                        });
                    }
                });
        }
    }
});

(3)在Vue实例中注册store对象:

newVue({
  el: '#app',
  router,
  store,
  created (){
      store.dispatch('fetchMsg');
  },
  template: '<App/>',
  components: { App }
})

(4)在组件中使用state数据:

必须通过computed属性使用state数据!否则state属性中的数据发生更改时不会反映在组件上!

export default{
        computed: {
            Msgs (){
                var Msgs = this.$store.state.NewMsg.Msgs;
                returnMsgs;
            }
        }
    }

注意事项: 

基本组成:

注意到这个store对象包含三个子对象:

state、mutations、actions

其中state用于存储数据,类似vue实例的data属性。

mutations用于递交更改,对state对象中的属性数据进行更改。

actions用于进行递交异步更改,通过调用mutations实现对数据的更改。

actions与mutations的区别:

其中actions区别于mutations的地方在于mutations只能进行同步更改,而actions中的更改可以是异步执行。所以基本上所有用户执行的直接数据更改都是触发mutations属性

函数执行,而需要与后端进行数据交互的数据更改通常是通过actions属性函数去执行。

定义actions与mutations属性函数的注意事项:

其中定义mutations属性函数时必须传递的第一个参数是state,因为要对state进行更改,第二个参数代表传入的新参数。mutations属性函数只接受两个参数,如果要同时更

改多个属性值,可以通过对象传入。

在actions属性函数中可以通过context.commit()方法触发mutations属性函数。定义actions属性函数时,必须传递的第一个参数是context,用于触发mutations函数。

触发actions与mutations属性函数的方法:

在子组件中通过this.$store.commit()方法触发mutations属性函数。在注册store的Vue实例中(第三步中将会讲到)可以通过store.commit()触发。

commit函数第一个参数是mutations的属性函数名,第二个参数是传入的新值。

actions属性函数中可以进行异步操作,比如通过ajax或者Vue.Resource()进行数据获取,获取数据后再通过context.commit()触发更改。

触发actions属性函数使用this.$store.dispatch()或者store.dispatch() (在注册store的Vue实例中)函数。dispatch函数传递的一个参数是actions属性函数名称。如果希望在

Vue实例创建完成还未挂载时就从后端获取数据,则可以在created钩子函数中调用actions属性函数。

在组件中访问数据中心state的注意事项:

在Vue实例中可以通过this.$store.state对象获取state中的数据。如果希望在state中的数据发生更改之后,组件会自动更新,则应该使用组件的computed属性定义数据,而

不是通过data属性定义。如果使用data定义组件数据,则state中的数据发生更改之后组件不会发生变化。

export default{
        computed: {
            Msgs (){
                var Msgs = this.$store.state.NewMsg.Msgs;
                returnMsgs;
            }
        }
    }

免责声明:文章转载自《简单使用Vuex步骤及注意事项》仅用于学习参考。如对内容有疑问,请及时联系本站处理。

上篇piap.excel 微软 时间戳转换mssql sql server文件时间戳转换unix 导入mysql菜单树jstree.js插件几个主要事件汇总下篇

宿迁高防,2C2G15M,22元/月;香港BGP,2C5G5M,25元/月 雨云优惠码:MjYwNzM=

相关文章

聊聊 webpack 打包如何压缩包文件大小

想必很多人都经历过做完一个项目后,再打包发现某些文件非常大,导致页面加载时很慢,这就很影响用户体验了,所以在我经历了一些打包后,讲讲如何有效地缩小包体积,加快页面的首屏渲染 动态 polyfill 相信很多项目都会用到polyfill 那么一整个polyfill 会占据很多的空间,这个时候需要使用动态polyfill来解决这个问题了: 在 index.ht...

浅析vue实例的生命周期(生命周期钩子)

“每个 Vue 实例在被创建时都要经过一系列的初始化过程——例如,需要设置数据监听、编译模板、将实例挂载到 DOM 并在数据变化时更新 DOM 等” ,在不同的生命周期内会经历不同的钩子函数(生命周期函数),这就提供了将我们自己的代码写入的机会。如果将生命周期比作人的话,生命周期就是一个人的一生,生命钩子函数就相当于人的不同年龄段(幼年、青年、中年、老年)...

VUE路径问题

import: html文件中,通过script标签引入js文件。而vue中,通过import xxx from xxx路径的方式导入文件,不光可以导入js文件。“xxx”指的是为导入的文件起一个名称,不是指导入的文件的名称,相当于变量名。“xxx路径”指的是文件的相对路径. src下有components,router文件夹和App.vue文件,comp...

在浏览器上开发GO和Vue!(基于code-server)

在浏览器上开发GO和Vue!(基于code-server) 曾几何时,开发者们都被安装编程环境苦恼,尽管现在很多语言的开发环境已经不难装了,但是如果我们能有一个运行在云端的编译器,那么我们就可以随时随地通过浏览器编写、编译我们的代码啦!! 先看我们最终效果: 完美运行Go程序!下面开始整个环境搭建。 打包好的镜像 配置完成的Go+Vue的编译+Debug...

VSCode 启动 Vue 项目 npm install 报错

1. 报错后,查看了版本。 查看node版本:node -v 查看npm版本:npm -v 查看Augular版本:ng --version 2. 感觉 Augular CLI版本太低,使用以下方法升级到最新版本: 》 npm uninstall -g @angular/cli 》 npm cache verify (或 npm cache clean -...

vue 项目中 js命名规则

类型 规范 示例 常量 全字符大写,单词用 '_' 分隔 FETCH_USERS、GET_USERS 变量、函数 小写开头驼峰式 camelCase 类、特殊意义的命名空间 大写开头驼峰式 CamelCase 方法、函数 a. 动词 或 动词+名称 组合b. get 必须要有返回值 布尔值变量 is 或 has 前缀 私有...