Объектно-ориентированные данные в Vue.JS

У меня есть простой пример Vue.JS, имитирующий людей, играющих в лотерею. Я ввожу имена игроков, помещаю их в список и выводю их на экран. В конце я нахожу победителя, которого выбирают из списка. Я хочу изменить это на объектно-ориентированный пример. Я хочу иметь объект игрока с двумя атрибутами; Имя Сумма (сумма, с которой играли) Итак, у меня должно быть два поля ввода, а кнопка ДОБАВИТЬ должна добавить объект игрока в список игроков.

Это мой код

<!DOCTYPE html>
<html lang="en">

<head>
   <meta charset="UTF-8">
   <meta name="viewport" content="width=device-width, initial-scale=1.0">
   <meta http-equiv="X-UA-Compatible" content="ie=edge">
   <link href="https://fonts.googleapis.com/css?family=Anton|Roboto:300,400,500" rel="stylesheet">
   <script src="https://cdn.jsdelivr.net/npm/vue/dist/vue.js"></script>
   <title>Who pays the bill</title>
</head>
<style>
   body {
font-family: 'Roboto', sans-serif;
padding:0;
margin:0;
}

a {
text-decoration: none;
color:#ffffff;
}

.container {
min-height: 300px;
width: 360px;
position: absolute;
left: 50%;
top: 50%;
-webkit-transform: translate(-50%, -50%);
transform: translate(-50%, -50%);
}

h1 {
color: #2196F3;
font-size: 40px;
text-align: center;
}

.input_container {
display: flex;
}
input:focus{
outline: none;
}
input {
flex-grow: 1;
border: 1px solid #dddddd;
background: #f2f2f2;
font-size: 20px;
border-radius: 5px 0px 0px 5px;
padding: 10px;
box-sizing: border-box;
}

button {
border-radius: 0px 5px 5px 0px;
background: #2196F3;
color: #ffffff;
font-size: 16px;
padding: 10px;
box-sizing: border-box;
}

.list_of_names {
padding: 10px 0px;
cursor: pointer;
}

.list_of_names div {
margin-right: 10px;
margin-bottom: 10px;
background: #2196F3;
color: #ffffff;
display: inline-block;
padding: 5px 10px;
border-radius: 15px;
}

.error_message {
color: #F44336;
font-weight: 600;
text-align: center;
margin-top: 10px;
}

.action_button {
cursor: pointer;
border: 1px solid #607D8B;
color: #607D8B;
font-size: 16px;
width: 200px;
text-align: center;
padding: 10px;
border-radius: 11px;
margin: 0 auto;
}

.action_button:hover {
background: #607D8B;
color:#ffffff;
}

.result_value {
font-size: 70px;
color: #607D8B;
font-weight: 600;
text-align: center;
margin-bottom: 20px;
}
</style>

<body>

   <div id="app">

      <div id="names" class="container" v-if="state">
         <h1>Who Wins The Lottery?</h1>
         <div class="input_container">
            <input type="text" v-model="inputName">
            <button @click="addNameToList">ADD</button>
         </div>
         <div class="error_message" v-if="showError">
            Please enter a name !!!
         </div>
         <div class="list_of_names">
            <div v-for="(name,index) in names" :key="index" @click="removeName(index)">
               {{ name }}
            </div>
         </div>
         <div v-if="names.length > 1">
            <div class="action_button" @click="showResults">
               Check the winner
            </div>
         </div>
      </div>
      <div id="result" class="container" v-if="!state">
         <div class="result_container">
            <h1>The winner is:</h1>
            <div class="result_value">{{ result }}</div>
            <div class="action_button" @click="resetApp">
               Start again
            </div>

         </div>

      </div>
   </div>

</body>


<script>
   new Vue({
      el: '#app',
      data: {
         state: true,
         inputName: '',
         names: [],
         showError: false,
         result: ''
      },
      methods: {
         addNameToList() {
            if (this.validate(this.inputName)) {
               this.names.push(this.inputName);
               this.inputName = '';
               this.showError = false;
            } else {
               this.showError = true;
            }
         },
         removeName(index) {
            this.names.splice(index, 1);
         },
         validate(value) {
            if (value !== '') {
               return true
            } else {
               return false
            }
         },
         showResults() {
            let rand = this.names[Math.floor(Math.random()*this.names.length)]
            this.result = rand;
            this.state = false
         },
         resetApp() {
            this.state = true;
            this.names = [];
            this.result = ''
         }
      }
   })
</script>

</html>

Я пробовал это, но это не работает

  <div id="names" class="container" v-if="state">
    <h1>Who Wins The Lottery?</h1>
    <div class="input_container">
      Name: <input type="text" v-model="Player.inputName" />
    </div>
    <br />
    <div class="input_container">
      Amount: <input type="text" v-model="Player.inputAmount" />
    </div>
    <br />
    <div class="input_container">
      <button @click="addNameToList">ADD</button>
    </div>

С этим javascript

new Vue({
  el: "#app",
  data: {
    state: true,
    Player={
       inputName: "",
       InputAmount,
    },
    //inputName: "",
    Players: [],
    showError: false,
    result: ""
  },
  methods: {
    addNameToList() {
      //if (this.validate(this.Player.inputName)) 
      alert(this.Player.inputName);
        this.names.push(this.Players.player);

        this.Player.inputName = "";
        this.Player.InputAmount = "";


    },
    removeName(index) {
      this.names.splice(index, 1);
    },

Я думаю, проблема в директиве v-модели. Можно ли v-моделировать объект так, чтобы связка полей HTML соответствовала атрибутам объекта данных? Есть идеи?

0 ответов

Другие вопросы по тегам