如何通过vue js更改JSON对象的密钥名称

问题描述 投票:1回答:1

使用vue更改JSON对象的键名“User1”和“User2”时遇到一些问题。

myJSON = {"User1": {"damage": "10000"}, "User2": {"damage": "10000"}}
users = ["User1","User2","User3","User4"]

这是循环代码和一些注释。其实问题是我不能在v-model中使用“key”...

<div class="mb-3" v-for="(item, key, index) in myJSON">
 <el-select v-model="key" filterable placeholder="Select"> // This is doesn't work - it's my problem =)
  <el-option
   v-for="cl in users"
   :key="cl"
   :label="cl"
   :value="cl">
  </el-option>
 </el-select>
 <el-input-number v-model="item.damage"></el-input-number> // It's okey, damage is changing.
</div>

我已经尝试更改v-model:

v-model="item.key" // JSON after this
myJSON = {"User1": {"damage": "10000", "key": "User3"}, "User2": {"damage": "10000", "key": "User4"}}

v-model="myJSON[key]" // Have error
TypeError: Cannot read property 'myJSON' of undefined

v-model="myJSON[key]" // Same
TypeError: Cannot read property 'myJSON' of undefined

<el-select>中选择用户后,我需要像这样的smth:

{"User2": {"damage": "10000"}, "User3": {"damage": "10000"}}

要么

{"User3333": {"damage": "10000"}, "User312321": {"damage": "10000"}}

但是我的方法不对,请帮忙。

vue.js v-for v-model
1个回答
0
投票

不确定您是否可以使用v-model直接更改obj的密钥,但有一种解决方法。

<div id="app">
 <ol>
  <li v-for="(item, index) in myJSON_format2">
   {{item}}
   <input v-model="item.damage"/>
   <input v-model="item.key"/>
  </li>
 </ol>
</div>

new Vue({
 el: "#app",
 data: {
  myJSON: {"User1": {"damage": "10000"}, "User2": {"damage": "10000"}},
  myJSON_format2: []
 },
 methods: {
  change_myJSON_toFormat2 () {
    for (let i in this.myJSON) {
     this.myJSON_format2.push({ damage: this.myJSON[i].damage, key: i })
    }
  }
 },
 created () {
  this.change_myJSON_toFormat2()
 }
})

请在这里查看:https://jsfiddle.net/shivampesitbng/dync94kt/24/

  • 解决方法: 将myjson的ds更改为obj数组 在vue-template中用v-for循环arr 当您更改“损坏”键时,更改了“用户”键。
© www.soinside.com 2019 - 2024. All rights reserved.