Heim > Web-Frontend > Front-End-Fragen und Antworten > Warum bearbeitet das Vue-Kontrollkästchen 0?

Warum bearbeitet das Vue-Kontrollkästchen 0?

WBOY
Freigeben: 2023-05-24 09:29:07
Original
571 Leute haben es durchsucht

vue ist ein beliebtes JavaScript-Framework zum Erstellen von Benutzeroberflächen. Eine gemeinsame Komponente ist ein Kontrollkästchen, mit dem der Benutzer zwischen mehreren Optionen wählen kann. Wenn wir jedoch den Wert des Kontrollkästchens bearbeiten, wird er manchmal zu 0, was nicht unseren Erwartungen entspricht. In diesem Artikel werden die Ursache dieses Problems und seine Lösung erläutert.

Werfen wir zunächst einen Blick auf die grundlegende Verwendung von Kontrollkästchen in Vue. Wir können die V-Model-Direktive verwenden, um den Wert des Kontrollkästchens zu binden:

<template>
  <div>
    <input type="checkbox" v-model="checked" />
    {{ checked }}
  </div>
</template>

<script>
export default {
  data() {
    return {
      checked: false
    }
  }
}
</script>
Nach dem Login kopieren

Im obigen Beispiel binden wir den Wert des Kontrollkästchens an das aktivierte Attribut. Wenn das Kontrollkästchen aktiviert ist, ist der aktivierte Wert wahr, andernfalls ist er falsch. Wir können den aktivierten Wert in der Vorlage anzeigen, um zu überprüfen, ob das Kontrollkästchen wie erwartet funktioniert.

Jetzt versuchen wir, den Wert des Kontrollkästchens zu bearbeiten. Wenn der Benutzer beispielsweise auf ein Kontrollkästchen klickt, möchten wir dessen Wert auf 1 statt auf „true“ setzen. Wir können dies erreichen, indem wir auf das Änderungsereignis des Kontrollkästchens hören:

<template>
  <div>
    <input type="checkbox" v-model="checked" @change="handleChange" />
    {{ checked }}
  </div>
</template>

<script>
export default {
  data() {
    return {
      checked: false
    }
  },
  methods: {
    handleChange() {
      if (this.checked) {
        this.checked = 1
      } else {
        this.checked = 0
      }
    }
  }
}
</script>
Nach dem Login kopieren

Im obigen Code haben wir einen Änderungsereignis-Listener für das Kontrollkästchen hinzugefügt. Wenn sich der Wert des Kontrollkästchens ändert, wird die handleChange-Methode aufgerufen. Bei dieser Methode setzen wir den überprüften Wert auf 1 bzw. 0, um unsere Anforderungen zu erfüllen.

Wenn wir jedoch den obigen Code ausführen, werden wir feststellen, dass der Wert des Kontrollkästchens 0 statt 1 wird. Dies liegt daran, dass Vue den Kontrollkästchenwert als Zeichenfolge und nicht als numerischen Wert analysiert. Wenn Sie also „checked“ den Wert 1 zuweisen, wird dieser als Zeichenfolge „1“ und nicht als Wert 1 geparst. Wenn der Wert des Kontrollkästchens wieder in einen numerischen Wert umgewandelt wird, wird er zu 0, da „1“ als unwahrer Wert interpretiert wird und bei der Umwandlung in einen numerischen Wert 0 ist.

Wie lösen wir dieses Problem? Eine Möglichkeit besteht darin, die parseInt-Methode zu verwenden, um eine Zeichenfolge in einen numerischen Wert umzuwandeln:

<template>
  <div>
    <input type="checkbox" v-model="checked" @change="handleChange" />
    {{ checked }}
  </div>
</template>

<script>
export default {
  data() {
    return {
      checked: false
    }
  },
  methods: {
    handleChange() {
      if (this.checked) {
        this.checked = parseInt(1)
      } else {
        this.checked = parseInt(0)
      }
    }
  }
}
</script>
Nach dem Login kopieren

Im obigen Code haben wir die parseInt-Methode verwendet, um die numerischen Werte 1 und 0 in numerische Typen umzuwandeln. Auf diese Weise bleibt der Wert des Kontrollkästchens bei der Rückkonvertierung in einen numerischen Typ 1 statt 0.

Eine andere Lösung ist die Verwendung des Number-Typs, der eine Zeichenfolge in einen numerischen Wert konvertieren kann:

<template>
  <div>
    <input type="checkbox" v-model="checked" @change="handleChange" />
    {{ checked }}
  </div>
</template>

<script>
export default {
  data() {
    return {
      checked: false
    }
  },
  methods: {
    handleChange() {
      if (this.checked) {
        this.checked = Number(1)
      } else {
        this.checked = Number(0)
      }
    }
  }
}
</script>
Nach dem Login kopieren

Im obigen Code haben wir die Number-Methode verwendet, um eine Zeichenfolge in einen numerischen Typ umzuwandeln. Auf diese Weise bleibt der Wert des Kontrollkästchens bei der Rückkonvertierung in einen numerischen Typ 1 statt 0.

Um es zusammenzufassen: Wenn wir den Wert des Kontrollkästchens in Vue bearbeiten, müssen wir beachten, dass diese als Zeichenfolgen und nicht als numerische Werte analysiert werden. Um dieses Problem zu vermeiden, können Sie die Zeichenfolge mit der Methode parseInt oder Number in einen numerischen Typ konvertieren. Auf diese Weise können wir den Wert des Kontrollkästchens erfolgreich bearbeiten!

Das obige ist der detaillierte Inhalt vonWarum bearbeitet das Vue-Kontrollkästchen 0?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage