⊗jsvuPmLpKA 34 of 72 menu

Vue में key एट्रिब्यूट

Vue द्वारा v-for डायरेक्टिव से रेंडर किए गए एलिमेंट्स की लिस्ट अपडेट करते समय, डिफ़ॉल्ट रूप से "इन-प्लेस" अपडेट स्ट्रैटेजी का उपयोग किया जाता है। यदि ऐरे या ऑब्जेक्ट के एलिमेंट्स का क्रम बदल गया है, तो Vue DOM एलिमेंट्स को स्थानांतरित नहीं करेगा, बल्कि प्रत्येक एलिमेंट को "इन-प्लेस" अपडेट कर देगा, ताकि वह संबंधित इंडेक्स पर नए डेटा को प्रदर्शित कर सके।

Vue को यह बताने के लिए कि प्रत्येक एलिमेंट की पहचान कैसे确定 की जाए, और इस प्रकार, मौजूदा एलिमेंट्स का पुन: उपयोग और क्रमबद्ध किया जाए, प्रत्येक एलिमेंट के लिए एक यूनिक एट्रिब्यूट key निर्दिष्ट करना आवश्यक है।

कुंजियों के बिना, Vue एक ऐसी एल्गोरिदम का उपयोग करता है जो एलिमेंट्स के स्थानांतरण को कम से कम करती है और एक ही प्रकार के एलिमेंट्स को अधिकतम संभव परिवर्तित/पुन: उपयोग करने का प्रयास करेगी। कुंजियों का उपयोग करने पर, एलिमेंट्स कुंजियों के क्रम में परिवर्तन के अनुसार पुन: क्रमबद्ध होंगे, और those एलिमेंट्स जिनकी कुंजियां अब मौजूद नहीं हैं, हमेशा हटा दिए/नष्ट कर दिए जाएंगे।

v-for के साथ key एट्रिब्यूट निर्दिष्ट करने की हमेशा सिफारिश की जाती है, सिवाय उन मामलों के जब DOM सामग्री सरल है, या जब आप जानबूझकर प्रदर्शन में सुधार के लिए डिफ़ॉल्ट अपडेट रणनीति पर भरोसा करते हैं।

आम तौर पर, कुंजियों को जोड़ने का सवाल तब उठता है जब ऑब्जेक्ट्स की एक सरणी पर पुनरावृति की जाती है। इस मामले में, ऑब्जेक्ट की कुंजियों में से एक एक यूनिक फ़ील्ड होती है, उदाहरण के लिए, id:

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

आइए दिए गए ऐरे पर लूप के साथ पुनरावृति करें, संबंधित कुंजियाँ निर्दिष्ट करते हुए:

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

निम्नलिखित ऐरे पर लूप के साथ पुनरावृति करें और उत्पादों के नामों को ul लिस्ट के रूप में प्रदर्शित करें:

data() { return { products: [ { id: 1, name: 'product1', }, { id: 2, name: 'product2', }, { id: 3, name: 'product3', }, ] } }
हिन्दी
AfrikaansAzərbaycanБългарскиবাংলাБеларускаяČeštinaDanskDeutschΕλληνικάEnglishEspañolEestiSuomiFrançaisMagyarՀայերենIndonesiaItaliano日本語ქართულიҚазақ한국어КыргызчаLietuviųLatviešuМакедонскиMelayuမြန်မာNederlandsNorskPolskiPortuguêsRomânăРусскийසිංහලSlovenčinaSlovenščinaShqipСрпскиSrpskiSvenskaKiswahiliТоҷикӣไทยTürkmenTürkçeЎзбекOʻzbekTiếng Việt
हम साइट के कार्य, विश्लेषण और व्यक्तिगतकरण के लिए कुकीज़ का उपयोग करते हैं। डेटा प्रसंस्करण गोपनीयता नीति के अनुसार किया जाता है।
सभी स्वीकार करें कॉन्फ़िगर करें अस्वीकार करें