vue+element,求助大佬为什么这样写改变不了 input 和 radio 的值? - V2EX
V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
请不要在回答技术问题时复制粘贴 AI 生成的内容
zzlit
V2EX    程序员

vue+element,求助大佬为什么这样写改变不了 input 和 radio 的值?

  •  
  •   zzlit 2019-02-22 09:20:49 +08:00 4058 次点击
    这是一个创建于 2424 天前的主题,其中的信息可能已经有所发展或是发生改变。
    <template> <div class="container"> <div v-for="(item, index) in arr1" :key="index" > <el-button type="primary" @click="addArr"><span>添加</span></el-button> <el-button type="primary" @click="adddata"><span>添加数据</span></el-button> <el-table border :data="item.arr2" style="width: 400px;"> <el-table-column label="input"> <template slot-scope="scope"> <el-input class="operate-input" v-model="scope.row.input" /> </template> </el-table-column> <el-table-column label="是否默认已选" width="182"> <template slot-scope="scope"> <el-radio-group v-model="scope.row.select"> <el-radio :label="0">否</el-radio> <el-radio :label="1">是</el-radio> </el-radio-group> </template> </el-table-column> </el-table> </div> </div> </template> <script> export default { name: 'HelloWorld', data () { return { arr1: [{arr2: []}] } }, watch: { arr1: (e) => { e.forEach(value => { value.arr2.forEach(item => { item.input = '2' item.select = 1 }) }) } }, methods: { addArr () { this.arr1.push({arr2: []}) }, adddata () { let data = { value: 1, date: '2018-8-8' } this.arr1.forEach(item => { item.arr2.push(data) }) this.arr1 = Array.from(this.arr1) } } } </script> <style scoped> </style> 
    第 1 条附言    2019-02-22 10:27:54 +08:00
    更新!楼主这个问题已经解决了,在拿到后台的数据 res.data.data 那数组里面去添加默认值然后就可以修改了,只是有点不理解为什么我在 watch 里面去给这个数组赋值就修改不了,感谢回复的各位!
    10 条回复    2019-02-22 11:16:12 +08:00
    caviare
        1
    caviare  
       2019-02-22 10:18:21 +08:00
    你把 arr1 的 watch 删掉
    wake1bear
        2
    wake1bear  
       2019-02-22 10:20:56 +08:00
    楼主把 watch 去掉试试看,讲道理 watch 只是会浅监听,在改变 input 或者 radio 的时候不会触发到,但我试了试把 watch 去掉确实没问题了,adddata 可以这样写
    ```javascrpit
    adddata () {
    let data = {
    value: 1,
    date: '2018-8-8',
    input = '2',

    }
    this.arr1.forEach(item => {
    item.arr2.push(data)
    })
    this.arr1 = Array.from(this.arr1)
    }
    ```
    zzlit
        3
    zzlit  
    OP
       2019-02-22 10:21:40 +08:00
    @caviare 感谢回复!但是我需要给它一个初始值的并且去监听改变,这里只是写一个例子出来
    wake1bear
        4
    wake1bear  
       2019-02-22 10:22:32 +08:00
    接上条,没敲完就发出去了
    adddata () {
    let data = {
    value: 1,
    date: '2018-8-8',
    input = '2',
    select = 1
    }
    this.arr1.forEach(item => {
    item.arr2.push(data)
    })
    this.arr1 = Array.from(this.arr1)
    }

    一样的效果
    @wake1bear
    zzlit
        5
    zzlit  
    OP
       2019-02-22 10:25:15 +08:00
    @wake1bear 对,这样写是的确可以的,但是我在我这边实际使用不行,所以我就想知道为什么在 watch 里面去赋值不能改变。。感谢回复!
    caviare
        6
    caviare  
       2019-02-22 10:40:04 +08:00
    不要去掉 watch 然后加上 @wake1bear 修改过的 adddata 函数
    wake1bear
        7
    wake1bear  
       2019-02-22 10:47:46 +08:00
    @caviare watch 不去不行,这么写逻辑是有误的,arr1 的第一层或第二层改变的时候必然会触发 watch,那么 watch 里的函数就会把 arr1 里的 arr2 每个元素都重新赋值一遍。
    caviare
        8
    caviare  
       2019-02-22 10:56:20 +08:00
    是的会有这种问题 没考虑到 勿用
    salinapper
        9
    salinapper  
       2019-02-22 11:05:21 +08:00
    正确答案是,adddata 里面需要改成
    let data = {
    value: 1,
    date: '2018-8-8',
    input: '',
    select: 0
    }

    因为这里是给这个 data 进行 defineProperty 操作的地方。
    这里没有 input、select 的话,你在 watch 里面动态添加的 input、select 属性是无法被 vue 监听的。
    salinapper
        10
    salinapper  
       2019-02-22 11:16:12 +08:00
    同理,watch 里面改成

    Vue.set(item, 'input', '2')
    Vue.set(item, 'select', 1)

    也是可以的,不过不推荐。
    关于     帮助文档     自助推广系统     博客     API     FAQ     Solana     2348 人在线   最高记录 6679       Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 24ms UTC 15:53 PVG 23:53 LAX 08:53 JFK 11:53
    Do have faith in what you're doing.
    ubao snddm index pchome yahoo rakuten mypaper meadowduck bidyahoo youbao zxmzxm asda bnvcg cvbfg dfscv mmhjk xxddc yybgb zznbn ccubao uaitu acv GXCV ET GDG YH FG BCVB FJFH CBRE CBC GDG ET54 WRWR RWER WREW WRWER RWER SDG EW SF DSFSF fbbs ubao fhd dfg ewr dg df ewwr ewwr et ruyut utut dfg fgd gdfgt etg dfgt dfgd ert4 gd fgg wr 235 wer3 we vsdf sdf gdf ert xcv sdf rwer hfd dfg cvb rwf afb dfh jgh bmn lgh rty gfds cxv xcv xcs vdas fdf fgd cv sdf tert sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf shasha9178 shasha9178 shasha9178 shasha9178 shasha9178 liflif2 liflif2 liflif2 liflif2 liflif2 liblib3 liblib3 liblib3 liblib3 liblib3 zhazha444 zhazha444 zhazha444 zhazha444 zhazha444 dende5 dende denden denden2 denden21 fenfen9 fenf619 fen619 fenfe9 fe619 sdf sdf sdf sdf sdf zhazh90 zhazh0 zhaa50 zha90 zh590 zho zhoz zhozh zhozho zhozho2 lislis lls95 lili95 lils5 liss9 sdf0ty987 sdft876 sdft9876 sdf09876 sd0t9876 sdf0ty98 sdf0976 sdf0ty986 sdf0ty96 sdf0t76 sdf0876 df0ty98 sf0t876 sd0ty76 sdy76 sdf76 sdf0t76 sdf0ty9 sdf0ty98 sdf0ty987 sdf0ty98 sdf6676 sdf876 sd876 sd876 sdf6 sdf6 sdf9876 sdf0t sdf06 sdf0ty9776 sdf0ty9776 sdf0ty76 sdf8876 sdf0t sd6 sdf06 s688876 sd688 sdf86