⊗jsvuPmFmAOOE 56 of 72 menu

Form til redigering af objektarray i Vue

Lad os nu implementere redigering af elementer i et objektarray. Vi laver en knap, der, når der klikkes på den, vil få en form til redigering til at vises i listeelementet. Efter udfyldning af formen vil vi klikke på knappen for at gemme, og ændringerne vil blive gemt i arrayet, og formen vil fjernes.

Lad os gå i gang med implementeringen. I objektarrayet skal vi tilføje endnu et felt til hvert objekt, der indeholder brugerens tilstand, visning eller redigering:

data() { return { users: [ { id: 1, name: 'name1', surn: 'surn1', isEdit: false, }, { id: 2, name: 'name2', surn: 'surn2', isEdit: false, }, { id: 3, name: 'name3', surn: 'surn3', isEdit: false, }, ] } }

Lad os udskrive indholdet af arrayet som en liste:

<template> <ul> <li v-for="user in users" :key="user.id"> {{ user.name }} {{ user.surn }} </li> </ul> </template>

Lad os nu adskille visningstilstand og redigeringstilstand:

<template> <ul> <li v-for="user in users" :key="user.id"> <template v-if="!user.isEdit"> {{ user.name }} {{ user.surn }} <button @click="edit(user)"> edit </button> </template> <template v-else> <input v-model="user.name"> <input v-model="user.surn"> <button @click="save(user)"> save </button> </template> </li> </ul> </template>

Lad os implementere metoderne:

methods: { edit(user) { user.isEdit = true; }, save(user) { user.isEdit = false; }, }

Modificer opgaven fra den forrige lektion, så der vises en kolonne med links til redigering af hver medarbejder.

Dansk
AfrikaansAzərbaycanБългарскиবাংলাБеларускаяČeštinaDeutschΕλληνικάEnglishEspañolEestiSuomiFrançaisहिन्दीMagyarՀայերենIndonesiaItaliano日本語ქართულიҚазақ한국어КыргызчаLietuviųLatviešuМакедонскиMelayuမြန်မာNederlandsNorskPolskiPortuguêsRomânăРусскийසිංහලSlovenčinaSlovenščinaShqipСрпскиSrpskiSvenskaKiswahiliТоҷикӣไทยTürkmenTürkçeЎзбекOʻzbekTiếng Việt
Vi bruger cookies til webstedets funktion, analyse og personalisering. Behandling af data foregår i henhold til Fortrolighedspolitikken.
accepter alle tilpas afvis