V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
starvedcat
V2EX  ›  Vue.js

data()里的属性重复初始化

  •  
  •   starvedcat · 2018-05-30 05:10:58 +08:00 · 2257 次点击
    这是一个创建于 2398 天前的主题,其中的信息可能已经有所发展或是发生改变。
    export default {
    data () {
    return {
      isA: false,
      isB: false,
      isC: true
    }
    },
    
    created () {
    this.fetchResult()
    },
    
    watch:{
    '$route': function () {
    this.fetchResult()
    }
    },
    
    methods: {
    fetchResult () {
      this.isA = false,
      this.isB = false,
      this.isC = true
      // fetching result ...
    }
    }
    }
    
    

    如上面代码所示,我现在希望每次 fetchResult 的时候,都要重置那些this.isA, this.isB, this.isC的值为默认值,但是这样看起来就和 data()里重复了。想请问一下有没有一种优雅的、不重复的写法?

    8 条回复    2018-05-30 11:33:15 +08:00
    airyland
        1
    airyland  
       2018-05-30 06:03:43 +08:00   ❤️ 2
    如果只有几个值倒不用怎么纠结。

    const initStatus = {
    isA: false,
    isB: false,
    isC: true
    }


    data () {
    return {
    status: { ...iniStatus }
    }
    }


    fetchResult () {
    this.status = { ...iniStatus }
    }
    zjwshisb
        2
    zjwshisb  
       2018-05-30 08:49:25 +08:00   ❤️ 1
    Object.assign(this.data,this.$option.data())
    zjwshisb
        3
    zjwshisb  
       2018-05-30 08:51:50 +08:00
    上面漏写了个 s,options
    noe132
        4
    noe132  
       2018-05-30 10:12:13 +08:00 via Android   ❤️ 1
    打他。也是个函数,也可以调用其他函数。你可以专门写个初始化值得函数
    starvedcat
        5
    starvedcat  
    OP
       2018-05-30 11:07:45 +08:00
    @noe132 #4 但是最后不是要 return 那些变量吗?
    airyland
        6
    airyland  
       2018-05-30 11:16:02 +08:00
    发现上面写的 iniStatus 少打了个 t,理论上直接合并到 data 也是可以的,不用再定义多一个 status,个人习惯,初始化状态放一个 obj 这样感觉清晰一些。
    starvedcat
        7
    starvedcat  
    OP
       2018-05-30 11:22:03 +08:00
    @airyland #6 谢谢大佬,可是我还是不太明白,如果不定义一个 status,要怎么合并那些 isA, isB, isC 呢?
    noe132
        8
    noe132  
       2018-05-30 11:33:15 +08:00   ❤️ 1
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   2872 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 24ms · UTC 12:53 · PVG 20:53 · LAX 04:53 · JFK 07:53
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.