广东建业集团
广东建兴实业发展有限公司
资质服务热线:
176-2081-2252
建筑工程施工总承包公路工程施工总承包铁路工程施工总承包港口与航道工程施工总承包水利水电工程施工总承包电力工程施工总承包冶金工程施工总承包石油化工工程施工总承包市政公用工程施工总承包通信工程施工总承包机电工程施工总承包施工总承包资质地基基础工程专业承包起重设备安装工程专业承包预拌混凝土专业专业承包电子与智能化工程专业承包消防设施工程专业承包防水防腐保温工程专业承包桥梁工程专业承包隧道工程专业承包钢结构工程专业承包模板脚手架专业承包建筑装修装饰工程专业承包建筑机电安装工程专业承包建筑幕墙工程专业承包古建筑工程专业承包城市及道路照明工程专业承包公路路面工程专业承包公路路基工程专业承包公路交通工程专业承包铁路电务工程专业承包铁路辅轨架梁工程专业承包铁路电气化工程专业承包机场场道工程专业承包机场目视助航工程专业承包港口与海岸工程专业承包航道工程专业承包通航建筑物工程专业承包水利水电机电安装工程专业承包河湖整治工程专业承包输变电工程专业承包核工程专业承包海洋石油工程专业承包环保工程专业承包特种工程专业承包民航安管工程及机场弱电系统工程专业承包港航设备安装及水上交通工程专业承包水工金属结构制作与安装工程专业承包专业承包资质施工劳务资质工程设计资质工程监理资质工程勘察资质房地产开发企业资质安全生产许可证矿山工程施工总承包

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

使用Vuex的步骤:

(1)安装:

  1.使用npm安装:

    npm install vuex --save

  2.使用script标签引入

    <script src="/path/to/vue.js"></script>

    <script src="/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对象:
```new Vue({
el: '#app',
router,
store,
created (){
store.dispatch('fetchMsg');
},
template: '<App/>',
components: { App }
})

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

  

exportdefault{        computed:{Msgs(){varMsgs=this.$store.state.NewMsg.Msgs;returnMsgs;}}}
注意事项:   <pre>基本组成:    注意到这个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中的数据发生更改之后组件不会发生变化。</pre>复制代码

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



网站首页                  新闻资讯                   BIM专区                 培训课程                 教育产品                  讲师团队
联系QQ:258506508 手机号码:130000000 联系邮箱:xxx@.co.m
联系电话:000-000-0000