অগ্রাধিকার D নিয়ম: সতর্কতার সাথে ব্যবহার করুন
Vue-এর কিছু বৈশিষ্ট্য বিরল এজ কেস সামাল দিতে বা পুরোনো কোডবেস থেকে সহজে মাইগ্রেশনের জন্য তৈরি করা হয়েছে। তবে, এগুলোর অতিরিক্ত ব্যবহার আপনার কোড রক্ষণাবেক্ষণকে আরও কঠিন করে তুলতে পারে, এমনকি বাগের উৎসও হয়ে উঠতে পারে। এই নিয়মগুলো সম্ভাব্য ঝুঁকিপূর্ণ বৈশিষ্ট্যগুলোর উপর আলোকপাত করে এবং কখন ও কেন সেগুলো পরিহার করা উচিত তা বর্ণনা করে।
scoped কম্পোনেন্ট নির্বাচক
এলিমেন্ট নির্বাচকদের scoped এড়ানো উচিত।
scoped কম্পোনেন্ট নির্বাচকদের চেয়ে শ্রেণী নির্বাচকদের পছন্দ করুন, কারণ বড় সংখ্যক কম্পোনেন্ট নির্বাচক ধীর।
বিস্তারিত ব্যাখ্যা
স্কোপ স্টাইলতে, Vue কম্পোনেন্ট কম্পোনেন্টগুলিতে একটি অনন্য বৈশিষ্ট্য যোগ করে, যেমন data-v-f3f3eg9। তারপরে নির্বাচকদের সংশোধন করা হয় যাতে শুধুমাত্র এই বৈশিষ্ট্যের সাথে মিলে যাওয়া কম্পোনেন্টগুলি নির্বাচন করা হয় (যেমন button[data-v-f3f3eg9])।
সমস্যা হল যে বড় সংখ্যক কম্পোনেন্ট-অ্যাট্রিবিউট নির্বাচক (যেমন button[data-v-f3f3eg9]) ক্লাস-অ্যাট্রিবিউট নির্বাচকদের তুলনায় যথেষ্ট ধীর হবে (যেমন .btn-close[data-v-f3f3eg9]), তাই যখনই সম্ভব ক্লাস নির্বাচকদের পছন্দ করা উচিত।
Bad
template
<template>
<button>×</button>
</template>
<style scoped>
button {
background-color: red;
}
</style>Good
template
<template>
<button class="btn btn-close">×</button>
</template>
<style scoped>
.btn-close {
background-color: red;
}
</style>অন্তর্নিহিত parent-child যোগাযোগ
parent-child কম্পোনেন্ট কমিউনিকেশনের জন্য প্রপস এবং ইভেন্টগুলিকে পছন্দ করা উচিত, এর পরিবর্তে this.$parent বা mutating props.
একটি আদর্শ Vue অ্যাপ্লিকেশন প্রপস ডাউন, ইভেন্ট আপ। এই কনভেনশনে লেগে থাকা আপনার কম্পোনেন্টগুলিকে বুঝতে অনেক সহজ করে তোলে। যাইহোক, এমন কিছু এজ কেস রয়েছে যেখানে প্রপ মিউটেশন বা this.$parent দুটি কম্পোনেন্টকে সরল করতে পারে যেগুলি ইতিমধ্যেই গভীরভাবে মিলিত হয়েছে।
সমস্যা হল, এমন অনেক সাধারণ ক্ষেত্রেও রয়েছে যেখানে এই নিদর্শনগুলি সুবিধা দিতে পারে। সতর্ক থাকুন: স্বল্পমেয়াদী সুবিধার জন্য (কম কোড লেখা) ট্রেডিং সরলতার (আপনার রাজ্যের প্রবাহ বুঝতে সক্ষম হওয়া) প্রলুব্ধ করবেন না।
Bad
vue
<script setup>
defineProps({
todo: {
type: Object,
required: true
}
})
</script>
<template>
<input v-model="todo.text" />
</template>vue
<script setup>
const props = defineProps({
todo: {
type: Object,
required: true
}
})
function renameTodo() {
// Mutates the parent's reactive object via the prop
// In other words, the child is reaching into and changing parent-owned state.
props.todo.text = 'renamed by child'
}
</script>
<template>
<span>
{{ todo.text }}
<button @click="renameTodo">rename</button>
</span>
</template>Good
vue
<script setup>
defineProps({
todo: {
type: Object,
required: true
}
})
const emit = defineEmits(['input'])
</script>
<template>
<input :value="todo.text" @input="emit('input', $event.target.value)" />
</template>vue
<script setup>
const props = defineProps({
todo: {
type: Object,
required: true
}
})
const emit = defineEmits(['update:todo'])
function renameTodo() {
// Emit a new object — the parent owns the update.
emit('update:todo', { ...props.todo, text: 'renamed by parent' })
}
</script>
<template>
<span>
{{ todo.text }}
<button @click="renameTodo">rename</button>
</span>
</template>