mixins和vuex区别

<a href='https://zhuanlan.zhihu.com/p/100941659'>vuex</a> (一个组件修改了state的数据、其他组件获取到的值是同步更新修改后的值、有的时候数据更新了页面没有更新可以通过this.$forceUpdate强制刷新)

# 优点:
    js 原生的数据对象写法, 比起 localStorage 不需要做转换, 使用方便
    属于 vue 生态一环, 能够触发响应式的渲染页面更新 (localStorage 就不会)
    限定了一种可预测的方式改变数据, 避免大项目中, 数据不小心的污染

# 缺点:
    刷新浏览器,vuex中的state会重新变为初始状态
    解决方案-插件 vuex-persistedstate
安装:npm i vuex -S
src下新建store文件夹index.js文件、或者直接vue ui方式创建项目时添加vuex
1.store文件夹下index.js
import Vue from 'vue'
import Vuex from 'vuex'

Vue.use(Vuex);
//然后在main.js引入并挂载

export default new Vuex.Store({
    /1. state存放公共数据
    state: { name: '张三',age: 18 },
    /2. getters相当于 vue中的computed属性,方法第一个参数是state、返回将state中数据计算的值
    getters: { val(state) { return state.name + '-' + state.age } },
    /3. mutations相当于 vue中的methods、只不过是写一些同步的逻辑代码修改state中的数据、其中写的方法第一个参数为state,第二个参数是携带的参数、在页面中通过this.$store.commit('addnum', { number: 5 })调用 addnum()方法
    mutations: { addnum(state, num) { state.age + num.number } },
    /4. actions类似于mutations、里面写异步逻辑代码,actions一般操作mutations、而不直接操作satate中的数据
    //getUserInfo()为异步的请求方法,返回一个对象,然后在组件methods中通过 this.$store.dispatch('getUserInfo')调用这个方法
    actions: { 
        async getUserInfo(context) { 
            //context相当于整个$Store对象、类似this.$store、包含state、getters、mutations、actions
           var res = await axios.get('url')
           //下面相当于this.$store.commit、第一个参数是mutations中的方法名、第二个参数是要传入的数据
           context.commit('setUserInfo', res)
            //下面调用 actions自己的 getToken()方法
           context.dispatch('getToken')
        } 
    }
});
2.main.js全局引入vuex并挂载
//引入vuex
import store from '@/store/index'

new Vue({
  //全局挂载vuex
  store,
  render: h => h(App),
}).$mount('#app')
3.所有组件都能直接使用vuex中的值、例如:App.vue
<template>
   <div>
    {{name}}
    {{age}}
       <div @click='addAge'></div>
   </div>
</template>
<script>
    //通过 mapState辅助函数简化 computed中的代码
    import { mapState } from 'vuex'
    //引入 mapGetesers辅助函数
    import { mapGetters } from 'vuex'
    //引入 mapMutations辅助函数 简化methods中的代码
    import { mapMutations } from 'vuex'
    //引入 mapAcsions辅助函数 简化methods中的代码
    import { mapActions } from 'vuex'
    export default {
        computed: {
            //computed 监听获取到 state中公共的值
            ...mapState(['name', 'age']),
            //computed 监听获取到 getters中计算的得到的值
            ...mapGetters('[val]')
        },
        methods() {
            //通过 mapMutations辅助函数简化 页面调用的addAge()方法
            ...mapMutations(['addAge']),
            //通过 mapActions辅助函数简化,调用 getUserInfo()请求方法
            ...mapActions(['getUserInfo'])
        },
    }
</script>

//1. computed: mapState(['name', 'age']) 相当于下面
computed: {
    name() { return this.$store.state.name},
    age() { return this.$store.state.age }
}


//2. 如果computed中有另外自定义计算属性、用es6的扩展运算符、
例如:
computed: {
    val() {},
    ...mapState(['name', 'age'])
}

//3. mapGetters('[val]')相当于下面
val() {
    this.$store.getters.val
}


//4. mapMutations(['addAge']) 相当于下面
addAge() {
     //这里调用 mutations中定义的 addnum()方法,调用时最好写成对象形式可以传递更多信息
     this.$store.commit('addnum', { number: 5 })
}


//5. mapActions(['getUserInfo']) 相当于下面
getUserInfo() {
    this.$store.dispatch('getUserInfo')
}
在实际开发当中,state里面的属性值是空的,当登录以后,再进行获取对应的信息。
登录以后,需要得到用户信息,那如何得到呢?
首先进入页面的时候调用actions中的getUserInfo方法
例如:
created(){ this.getUserInfo() }
methods:{ ...mapActions(['getUserInfo']) }

总结:

① 依赖state得到新的数据,用getters(跟computed一样,只读)

② 修改state的属性值,就用mutations(同步操作)

<a href='https://zhuanlan.zhihu.com/p/222466221'>mixins</a> (区别于vuex、mixins中一个组件修改了数据,其他组件获取到这个数据还是最开始没修改之前的值)

场景:解决项目中多出代码复用的情况
#局部引入mixins
1.src下新建文件夹mixins下创建index.js
里面写组件script中定义的data、computed、watch、methods、created等复用的代码
export const showMixin = {
    data() { return { num: 2 } },
    methods: { console.log('123') }
}

2.在其他组件引入
import { showMixin } from '@/mixins/index'
export default {
    mixins: [showMixin]
}

注意:
    1.如果组件 data中定义了和 mixins相同的属性、会以组件数据优先
    2.如果有同名的方法名、两个都会被调用、混入的方法先调用、组件自身的方法后调用

#全局引入
main.js中
Vue.mixin({
    created() { 
        const options = this.$option.myoption
        if () { console.log(myoption) }
    }
})

new Vue({
    option: { myoption: 'test' },
    render: h => h(App),
}).$mount('#app')

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 216,142评论 6 498
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,298评论 3 392
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 162,068评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,081评论 1 291
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,099评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,071评论 1 295
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,990评论 3 417
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,832评论 0 273
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,274评论 1 310
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,488评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,649评论 1 347
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,378评论 5 343
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,979评论 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,625评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,796评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,643评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,545评论 2 352

推荐阅读更多精彩内容

  • .什么是vue生命周期 Vue 实例从开始创建、初始化数据、编译模板、挂载Dom→渲染、更新→渲染、销毁等一系列过...
    酷酷的凯先生阅读 4,330评论 0 3
  • .什么是vue生命周期 Vue 实例从开始创建、初始化数据、编译模板、挂载Dom→渲染、更新→渲染、销毁等一系列过...
    酷酷的凯先生阅读 619评论 0 2
  • vue 1、 你知道vue的模板语法用的是哪个web模板引擎的吗?说说你对这模板引擎的理解 Vue使用了Musta...
    Aniugel阅读 9,567评论 3 21
  • axios和ajax的区别 axios是通过promise实现对ajax技术的一种封装axios可以运行nodej...
    yimi珊阅读 288评论 0 0
  • keep-alive 组件有什么作用? keep-alive 是 vue 的内置组件,一般情况下,组件进行切换的时...
    喜喜喜喜喜阅读 734评论 0 1