অগ্রাধিকার C নিয়ম: প্রস্তাবিত
যেখানে একাধিক, সমানভাবে ভাল বিকল্প বিদ্যমান, সেখানে ধারাবাহিকতা নিশ্চিত করার জন্য একটি নির্বিচারে পছন্দ করা যেতে পারে। এই নিয়মগুলিতে, আমরা প্রতিটি গ্রহণযোগ্য বিকল্প বর্ণনা করি এবং একটি ডিফল্ট পছন্দের পরামর্শ দিই। তার মানে আপনি আপনার নিজের কোডবেসে একটি ভিন্ন পছন্দ করতে নির্দ্বিধায় পারেন, যতক্ষণ না আপনি সামঞ্জস্যপূর্ণ এবং একটি ভাল কারণ আছে। যদিও একটি ভাল কারণ আছে দয়া করে! কমিউনিটি স্ট্যান্ডার্ডের সাথে খাপ খাইয়ে, আপনি করবেন:
- আপনার মস্তিস্ককে প্রশিক্ষিত করুন যাতে আপনি যে সম্প্রদায়ের কোডের মুখোমুখি হন তার বেশিরভাগই আরও সহজে পার্স করুন৷
- পরিবর্তন ছাড়াই বেশিরভাগ কমিউনিটি কোড উদাহরণ কপি এবং পেস্ট করতে সক্ষম হন
- প্রায়শই দেখুন নতুন নিয়োগকারীরা ইতিমধ্যেই আপনার পছন্দের কোডিং স্টাইলতে অভ্যস্ত, অন্তত Vue এর ক্ষেত্রে
কম্পোনেন্ট/ইনস্ট্যান্স অপশন অর্ডার
** কম্পোনেন্ট/ইনস্ট্যান্স বিকল্পগুলি ধারাবাহিকভাবে অর্ডার করা উচিত।**
এটি হল ডিফল্ট অর্ডার যা আমরা কম্পোনেন্ট বিকল্পগুলির জন্য সুপারিশ করি। এগুলি বিভাগগুলিতে বিভক্ত, তাই আপনি জানতে পারবেন কোথায় প্লাগইনগুলি থেকে নতুন বৈশিষ্ট্য যুক্ত করতে হবে৷
Global Awareness (উপাদানের বাইরে জ্ঞানের প্রয়োজন)
name
Template Compiler Options (টেমপ্লেট কম্পাইল করার পদ্ধতি পরিবর্তন করে)
compilerOptions
Template Dependencies (টেমপ্লেটে ব্যবহৃত সম্পদ)
componentsdirectives
Composition (অপশনের মধ্যে বৈশিষ্ট্য মার্জ করে)
extendsmixinsprovide/inject
Interface ( কম্পোনেন্টের ইন্টারফেস)
inheritAttrspropsemits
Composition API (কম্পোজিশন এপিআই ব্যবহার করার জন্য এন্ট্রি পয়েন্ট)
setup
Local State (স্থানীয় প্রতিক্রিয়াশীল বৈশিষ্ট্য)
datacomputed
Events (প্রতিক্রিয়াশীল ইভেন্ট দ্বারা ট্রিগার কলব্যাক)
watch- Lifecycle Events (যে ক্রমে বলা হয়)
beforeCreatecreatedbeforeMountmountedbeforeUpdateupdatedactivateddeactivatedbeforeUnmountunmountederrorCapturedrenderTrackedrenderTriggered
Non-Reactive Properties (প্রতিক্রিয়াশীলতা সিস্টেমের থেকে স্বাধীন উদাহরণ বৈশিষ্ট্য)
methods
Rendering ( কম্পোনেন্ট আউটপুটের ডিক্লেয়ার বিবরণ)
template/render
কম্পোনেন্ট বৈশিষ্ট্য ক্রম
উপাদানের গুণাবলী (উপাদান সহ) ধারাবাহিকভাবে অর্ডার করা উচিত।
এটি হল ডিফল্ট অর্ডার যা আমরা কম্পোনেন্ট বিকল্পগুলির জন্য সুপারিশ করি। এগুলি বিভাগগুলিতে বিভক্ত, তাই আপনি জানতে পারবেন কোথায় কাস্টম বৈশিষ্ট্য এবং নির্দেশাবলী যোগ করতে হবে৷
Definition (উপাদান বিকল্প প্রদান করে)
is
List Rendering (cএকই কম্পোনেন্টের একাধিক বৈচিত্র তৈরি করে)
v-for
Conditionals (উপাদানটি রেন্ডার/দেখানো হয়েছে কিনা)
v-ifv-else-ifv-elsev-showv-cloak
Render Modifiers (উপাদান রেন্ডার উপায় পরিবর্তন)
v-prev-once
Global Awareness (উপাদান অতিক্রম জ্ঞান প্রয়োজন)
id
Unique Attributes (বৈশিষ্ট্য যে অনন্য মান প্রয়োজন)
refkey
Two-Way Binding (বাঁধাই এবং ঘটনা একত্রিত করা)
v-model
Other Attributes (সমস্ত অনির্দিষ্ট আবদ্ধ এবং আনবাউন্ড বৈশিষ্ট্য)
Events ( কম্পোনেন্ট ইভেন্ট শ্রোতা)
v-on
Content (উপাদানের বিষয়অবজেক্ট ওভাররাইড করে)
v-htmlv-text
কম্পোনেন্ট/ইনস্ট্যান্স বিকল্পে খালি লাইন
আপনি মাল্টি-লাইন বৈশিষ্ট্যগুলির মধ্যে একটি খালি লাইন যোগ করতে চাইতে পারেন, বিশেষ করে যদি বিকল্পগুলি স্ক্রোল না করে আপনার স্ক্রিনে আর ফিট না হয়৷
যখন কম্পোনেন্টগুলি সঙ্কুচিত বা পড়তে অসুবিধা হতে শুরু করে, বহু-লাইন বৈশিষ্ট্যগুলির মধ্যে স্পেস যোগ করা তাদের আবার স্কিম করা সহজ করে তোলে। কিছু এডিটরে, যেমন Vim, এই ধরনের ফরম্যাটিং বিকল্পগুলি তাদের কীবোর্ড দিয়ে নেভিগেট করা আরও সহজ করে তুলতে পারে।
Bad
js
defineProps({
value: {
type: String,
required: true
},
focused: {
type: Boolean,
default: false
},
label: String,
icon: String
})
const formattedValue = computed(() => {
// ...
})
const inputClasses = computed(() => {
// ...
})Good
js
defineProps({
value: {
type: String,
required: true
},
focused: {
type: Boolean,
default: false
},
label: String,
icon: String
})
const formattedValue = computed(() => {
// ...
})
const inputClasses = computed(() => {
// ...
})Single-file component top-level element order
[একক-ফাইল কম্পোনেন্ট]](/guide/scaling-up/sfc) সর্বদা <script>, <টেমপ্লেট>, এবং <style> ট্যাগগুলিকে ধারাবাহিকভাবে, <style> শেষের সাথে অর্ডার করতে হবে, কারণ অন্য দুটির মধ্যে অন্তত একটি সর্বদা প্রয়োজনীয়।
Bad
template
<style>/* ... */</style>
<script>/* ... */</script>
<template>...</template>template
<!-- ComponentA.vue -->
<script>/* ... */</script>
<template>...</template>
<style>/* ... */</style>
<!-- ComponentB.vue -->
<template>...</template>
<script>/* ... */</script>
<style>/* ... */</style>Good
template
<!-- ComponentA.vue -->
<script>/* ... */</script>
<template>...</template>
<style>/* ... */</style>
<!-- ComponentB.vue -->
<script>/* ... */</script>
<template>...</template>
<style>/* ... */</style>template
<!-- ComponentA.vue -->
<template>...</template>
<script>/* ... */</script>
<style>/* ... */</style>
<!-- ComponentB.vue -->
<template>...</template>
<script>/* ... */</script>
<style>/* ... */</style>