કમ્પ્યુટેડ પ્રોપર્ટીઝ
મૂળભૂત ઉદાહરણ
ટેમ્પલેટમાં રહેલા એક્સપ્રેશન્સ (In-template expressions) ખૂબ અનુકૂળ છે, પરંતુ તે સાદા ઓપરેશન્સ માટે હોય છે. તમારા ટેમ્પલેટ્સમાં ખૂબ જ લોજિક મૂકવાથી તેઓ જટિલ અને જાળવણી કરવા મુશ્કેલ બની શકે છે. ઉદાહરણ તરીકે, જો આપણી પાસે નેસ્ટેડ એરે વાળું ઓબ્જેક્ટ હોય:
js
const author = reactive({
name: 'John Doe',
books: [
'Vue 2 - Advanced Guide',
'Vue 3 - Basic Guide',
'Vue 4 - The Mystery'
]
})અને આપણે author પાસે પહેલેથી જ પુસ્તકો છે કે નહીં તેના આધારે અલગ અલગ સંદેશાઓ પ્રદર્શિત કરવા માંગીએ છીએ:
template
<p>પુસ્તકો પ્રકાશિત થયા છે:</p>
<span>{{ author.books.length > 0 ? 'હા' : 'ના' }}</span>આ સ્થાને, ટેમ્પલેટ થોડું અસ્પષ્ટ (cluttered) બની રહ્યું છે. આપણે તેને એક સેકન્ડ માટે જોવું પડશે તે સમજવા માટે કે તે author.books પર આધારિત ગણતરી કરે છે. વધુ મહત્ત્વનું એ છે કે, જો આપણે ટેમ્પલેટમાં આ ગણતરીનો એકથી વધુ વાર સમાવેશ કરવાની જરૂર હોય તો આપણે તેને વારંવાર દોહરાવવા માંગતા નથી.
તેથી જ રિએક્ટિવ ડેટા ધરાવતા જટિલ લોજિક માટે, કમ્પ્યુટેડ પ્રોપર્ટી (computed property) નો ઉપયોગ કરવાની ભલામણ કરવામાં આવે છે. સમાન ઉદાહરણ અહીં રિફેક્ટર કરીને આપેલું છે:
vue
<script setup>
import { reactive, computed } from 'vue'
const author = reactive({
name: 'John Doe',
books: [
'Vue 2 - Advanced Guide',
'Vue 3 - Basic Guide',
'Vue 4 - The Mystery'
]
})
// એ કમ્પ્યુટેડ ref
const publishedBooksMessage = computed(() => {
return author.books.length > 0 ? 'હા' : 'ના'
})
</script>
<template>
<p>પુસ્તકો પ્રકાશિત થયા છે:</p>
<span>{{ publishedBooksMessage }}</span>
</template>અહીં આપણે કમ્પ્યુટેડ પ્રોપર્ટી publishedBooksMessage જાહેર કરી છે. computed() ફંક્શન અપેક્ષા રાખે છે કે તેને ગેટર ફંક્શન (getter function) પાસ કરવામાં આવે, અને પરત કરેલ મૂલ્ય એક કમ્પ્યુટેડ ref (computed ref) છે. સામાન્ય રિફ્સની જેમ, તમે કમ્પ્યુટેડ પરિણામને publishedBooksMessage.value તરીકે એક્સેસ કરી શકો છો. ટેમ્પલેટ્સમાં કમ્પ્યુટેડ રિફ્સ પણ ઓટો-અનવ્રેપ (auto-unwrapped) થાય છે જેથી તમે ટેમ્પલેટ એક્સપ્રેશન્સમાં .value વગર તેમનો સંદર્ભ લઈ શકો.
કમ્પ્યુટેડ પ્રોપર્ટી આપમેળે તેની રિએક્ટિવ ડિપેન્ડન્સી (reactive dependencies) ને ટ્રૅક કરે છે. Vue જાણે છે કે publishedBooksMessage ની ગણતરી author.books પર આધારિત છે, તેથી જ્યારે author.books બદલાશે ત્યારે તે publishedBooksMessage પર આધારિત કોઈપણ બાઈન્ડિંગ્સને અપડેટ કરશે.
આ પણ જુઓ: Typing Computed
કમ્પ્યુટેડ કેશીંગ (Caching) વિરુદ્ધ મેથડ્સ
તમે નોંધ્યું હશે કે આપણે એક્સપ્રેશનમાં મેથડ ઇનવોક (invoking) કરીને સમાન પરિણામ પ્રાપ્ત કરી શકીએ છીએ:
template
<p>{{ calculateBooksMessage() }}</p>js
// કમ્પોનન્ટમાં
function calculateBooksMessage() {
return author.books.length > 0 ? 'હા' : 'ના'
}કમ્પ્યુટેડ પ્રોપર્ટીને બદલે, આપણે સમાન ફંક્શનને મેથડ તરીકે વ્યાખ્યાયિત કરી શકીએ છીએ. અંતિમ પરિણામ માટે, બંને અભિગમો ખરેખર બરાબર સમાન છે. જો કે, તફાવત એ છે કે કમ્પ્યુટેડ પ્રોપર્ટીઝ તેમની રિએક્ટિવ ડિપેન્ડન્સીના આધારે કેશ (cached) થાય છે. કમ્પ્યુટેડ પ્રોપર્ટી ત્યારે જ ફરીથી મૂલ્યાંકન (re-evaluate) થશે જ્યારે તેની કેટલીક રિએક્ટિવ ડિપેન્ડન્સી બદલાઈ હશે. આનો અર્થ એ છે કે જે સુધી author.books બદલાયું નથી, ત્યાં સુધી publishedBooksMessage ની બહુવિધ એક્સેસ ગેટર ફંક્શનને ફરીથી ચલાવ્યા વગર અગાઉથી ગણતરી કરેલ પરિણામ તરત જ પરત કરશે.
આનો અર્થ એ પણ છે કે નીચેની કમ્પ્યુટેડ પ્રોપર્ટી ક્યારેય અપડેટ થશે નહીં, કારણ કે Date.now() રિએક્ટિવ ડિપેન્ડન્સી નથી:
js
const now = computed(() => Date.now())સરખામણીમાં, જ્યારે પણ રિન-રેન્ડર થાય ત્યારે મેથડ ઇન્વોકેશન (method invocation) હંમેશા ફંક્શન ચલાવશે.
આપણને કેશીંગ (caching) ની કેમ જરૂર છે? કલ્પના કરો કે આપણી પાસે એક ખર્ચાળ (expensive) કમ્પ્યુટેડ પ્રોપર્ટી list છે, જેને વિશાળ એરે દ્વારા લૂપિંગ કરવાની અને ઘણી બધી ગણતરીઓ કરવાની જરૂર છે. પછી આપણી પાસે અન્ય કમ્પ્યુટેડ પ્રોપર્ટીઝ હોઈ શકે છે જે બદલામાં list પર આધારિત હોય. કેશીંગ વિના, આપણે list ના ગેટરને જરૂર કરતાં ઘણી વધુ વાર ચલાવીશું! એવા કિસ્સામાં કે જ્યાં તમે કેશીંગ નથી ઈચ્છતા, તેના બદલે મેથડ કોલનો ઉપયોગ કરો.
રાઈટેબલ (Writable) કમ્પ્યુટેડ
કમ્પ્યુટેડ પ્રોપર્ટીઝ મૂળભૂત રીતે ફક્ત ગેટર-ઓન્લી (getter-only) હોય છે. જો તમે કમ્પ્યુટેડ પ્રોપર્ટીમાં નવી વેલ્યુ અસાઇન કરવાનો પ્રયાસ કરો છો, તો તમને રનટાઇમ વોર્નિંગ મળશે. દુર્લભ કિસ્સાઓમાં જ્યાં તમારે "રાઈટેબલ" કમ્પ્યુટેડ પ્રોપર્ટીની જરૂર હોય, તમે ગેટર અને સેટર બંને પ્રદાન કરીને એક બનાવી શકો છો:
vue
<script setup>
import { ref, computed } from 'vue'
const firstName = ref('John')
const lastName = ref('Doe')
const fullName = computed({
// getter
get() {
return firstName.value + ' ' + lastName.value
},
// setter
set(newValue) {
// નોંધ: આપણે અહીં ડિસ્ટ્રક્ચરિંગ અસાઇનમેન્ટ સિન્ટેક્સનો ઉપયોગ કરી રહ્યા છીએ.
[firstName.value, lastName.value] = newValue.split(' ')
}
})
</script>હવે જ્યારે તમે fullName.value = 'John Doe' ચલાવો છો, ત્યારે સેટર ઇનવોક થશે અને firstName અને lastName તે મુજબ અપડેટ કરવામાં આવશે.
અગાઉની વેલ્યુ મેળવવી
- ફક્ત 3.4+ માં સપોર્ટેડ છે
જો તમને તેની જરૂર હોય, તો તમે ગેટરની પ્રથમ આર્ગ્યુમેન્ટ એક્સેસ કરીને કમ્પ્યુટેડ પ્રોપર્ટી દ્વારા પરત કરેલ અગાઉની વેલ્યુ મેળવી શકો છો:
vue
<script setup>
import { ref, computed } from 'vue'
const count = ref(2)
// આ કમ્પ્યુટેડ કાઉન્ટની વેલ્યુ પરત કરશે જ્યારે તે 3 કરતા ઓછું અથવા સમાન હોય.
// જ્યારે કાઉન્ટ >=4 હોય, ત્યારે છેલ્લું મૂલ્ય જેણે અમારી શરત પૂરી કરી હતી તે પરત કરવામાં આવશે
// જ્યાં સુધી કાઉન્ટ 3 કે તેનાથી ઓછું ન થાય ત્યાં સુધી.
const alwaysSmall = computed((previous) => {
if (count.value <= 3) {
return count.value
}
return previous
})
</script>જો તમે રાઈટેબલ (writable) કમ્પ્યુટેડનો ઉપયોગ કરી રહ્યાં છો:
vue
<script setup>
import { ref, computed } from 'vue'
const count = ref(2)
const alwaysSmall = computed({
get(previous) {
if (count.value <= 3) {
return count.value
}
return previous
},
set(newValue) {
count.value = newValue * 2
}
})
</script>શ્રેષ્ઠ અભ્યાસો (Best Practices)
ગેટર્સ (Getters) સાઇડ-ઇફેક્ટ ફ્રી હોવા જોઈએ
એ યાદ રાખવું અગત્યનું છે કે કમ્પ્યુટેડ ગેટર ફંક્શન્સ માત્ર ગણતરી (computation) કરવા જોઈએ અને સાઇડ ઇફેક્ટ્સથી મુક્ત હોવા જોઈએ. ઉદાહરણ તરીકે, બીજા સ્ટેટ ને મ્યુટેટ (mutate) કરશો નહીં, એસિંક કોલ્સ કરશો નહીં, અથવા કમ્પ્યુટેડ ગેટરની અંદર DOM ને મ્યુટેટ કરશો નહીં! કમ્પ્યુટેડ પ્રોપર્ટીને અન્ય વેલ્યુ પર આધારિત વેલ્યુ કેવી રીતે મેળવવી તે ડિક્લેરેટિવ રીતે વર્ણવતા તરીકે વિચારો - તેની એકમાત્ર જવાબદારી તે વેલ્યુની ગણતરી અને પરત કરવાની હોવી જોઈએ. પછીથી માર્ગદર્શિકામાં આપણે ચર્ચા કરીશું કે કેવી રીતે આપણે watchers સાથે સ્ટેટ ફેરફારોની પ્રતિક્રિયામાં સાઇડ ઇફેક્ટ્સ કરી શકીએ છીએ.
કમ્પ્યુટેડ વેલ્યુ બદલવાનું ટાળો
કમ્પ્યુટેડ પ્રોપર્ટીમાંથી પરત મળેલ વેલ્યુ ડિરાઇવ્ડ (derived) સ્ટેટ છે. તેને કામચલાઉ સ્નેપશોટ તરીકે વિચારો - જ્યારે પણ સોર્સ સ્ટેટ બદલાય છે, ત્યારે નવો સ્નેપશોટ બનાવવામાં આવે છે. સ્નેપશોટને મ્યુટેટ કરવાનો કોઈ અર્થ નથી, તેથી કમ્પ્યુટેડ રિટર્ન મૂલ્યને ફક્ત વાંચવા માટે (read-only) ગણવું જોઈએ અને તેને ક્યારેય મ્યુટેટ કરવું જોઈએ નહીં - તેના બદલે, નવી ગણતરીઓને ટ્રિગર કરવા માટે તે જેના પર આધાર રાખે છે તે સોર્સ સ્ટેટને અપડેટ કરો.