অগ্রাধিকার C নিয়ম: প্রস্তাবিত
Note
এই Vue.js স্টাইল গাইড পুরানো এবং পর্যালোচনা করা প্রয়োজন৷ আপনার কোন প্রশ্ন বা পরামর্শ থাকলে, অনুগ্রহ করে একটি সমস্যা খুলুন।
যেখানে একাধিক, সমানভাবে ভাল বিকল্প বিদ্যমান, সেখানে ধারাবাহিকতা নিশ্চিত করার জন্য একটি নির্বিচারে পছন্দ করা যেতে পারে। এই নিয়মগুলিতে, আমরা প্রতিটি গ্রহণযোগ্য বিকল্প বর্ণনা করি এবং একটি ডিফল্ট পছন্দের পরামর্শ দিই। তার মানে আপনি আপনার নিজের কোডবেসে একটি ভিন্ন পছন্দ করতে নির্দ্বিধায় পারেন, যতক্ষণ না আপনি সামঞ্জস্যপূর্ণ এবং একটি ভাল কারণ আছে। যদিও একটি ভাল কারণ আছে দয়া করে! কমিউনিটি স্ট্যান্ডার্ডের সাথে খাপ খাইয়ে, আপনি করবেন:
- আপনার মস্তিস্ককে প্রশিক্ষিত করুন যাতে আপনি যে সম্প্রদায়ের কোডের মুখোমুখি হন তার বেশিরভাগই আরও সহজে পার্স করুন৷
- পরিবর্তন ছাড়াই বেশিরভাগ কমিউনিটি কোড উদাহরণ কপি এবং পেস্ট করতে সক্ষম হন
- প্রায়শই দেখুন নতুন নিয়োগকারীরা ইতিমধ্যেই আপনার পছন্দের কোডিং স্টাইলতে অভ্যস্ত, অন্তত Vue এর ক্ষেত্রে
কম্পোনেন্ট/ইনস্ট্যান্স অপশন অর্ডার
** কম্পোনেন্ট/ইনস্ট্যান্স বিকল্পগুলি ধারাবাহিকভাবে অর্ডার করা উচিত।**
এটি হল ডিফল্ট অর্ডার যা আমরা কম্পোনেন্ট বিকল্পগুলির জন্য সুপারিশ করি। এগুলি বিভাগগুলিতে বিভক্ত, তাই আপনি জানতে পারবেন কোথায় প্লাগইনগুলি থেকে নতুন বৈশিষ্ট্য যুক্ত করতে হবে৷
Global Awareness (কম্পোনেন্টস বাইরে জ্ঞানের প্রয়োজন)
name
Template Compiler Options (টেমপ্লেট কম্পাইল করার পদ্ধতি পরিবর্তন করে)
compilerOptions
Template Dependencies (টেমপ্লেটে ব্যবহৃত সম্পদ)
components
directives
Composition (অপশনের মধ্যে বৈশিষ্ট্য মার্জ করে)
extends
mixins
provide
/inject
Interface ( কম্পোনেন্টের ইন্টারফেস)
inheritAttrs
props
emits
Composition API (কম্পোজিশন এপিআই ব্যবহার করার জন্য এন্ট্রি পয়েন্ট)
setup
Local State (স্থানীয় প্রতিক্রিয়াশীল বৈশিষ্ট্য)
data
computed
Events (প্রতিক্রিয়াশীল ইভেন্ট দ্বারা ট্রিগার কলব্যাক)
watch
- Lifecycle Events (যে ক্রমে বলা হয়)
beforeCreate
created
beforeMount
mounted
beforeUpdate
updated
activated
deactivated
beforeUnmount
unmounted
errorCaptured
renderTracked
renderTriggered
Non-Reactive Properties (প্রতিক্রিয়াশীলতা সিস্টেমের থেকে স্বাধীন উদাহরণ বৈশিষ্ট্য)
methods
Rendering ( কম্পোনেন্ট আউটপুটের ডিক্লেয়ার বিবরণ)
template
/render
কম্পোনেন্ট বৈশিষ্ট্য ক্রম
কম্পোনেন্টস গুণাবলী (কম্পোনেন্ট সহ) ধারাবাহিকভাবে অর্ডার করা উচিত।
এটি হল ডিফল্ট অর্ডার যা আমরা কম্পোনেন্ট বিকল্পগুলির জন্য সুপারিশ করি। এগুলি বিভাগগুলিতে বিভক্ত, তাই আপনি জানতে পারবেন কোথায় কাস্টম বৈশিষ্ট্য এবং নির্দেশাবলী যোগ করতে হবে৷
Definition (কম্পোনেন্ট বিকল্প প্রদান করে)
is
List Rendering (cএকই কম্পোনেন্টের একাধিক বৈচিত্র তৈরি করে)
v-for
Conditionals (কম্পোনেন্টটি রেন্ডার/দেখানো হয়েছে কিনা)
v-if
v-else-if
v-else
v-show
v-cloak
Render Modifiers (কম্পোনেন্ট রেন্ডার উপায় পরিবর্তন)
v-pre
v-once
Global Awareness (কম্পোনেন্ট অতিক্রম জ্ঞান প্রয়োজন)
id
Unique Attributes (বৈশিষ্ট্য যে অনন্য মান প্রয়োজন)
ref
key
Two-Way Binding (বাঁধাই এবং ঘটনা একত্রিত করা)
v-model
Other Attributes (সমস্ত অনির্দিষ্ট আবদ্ধ এবং আনবাউন্ড বৈশিষ্ট্য)
Events ( কম্পোনেন্ট ইভেন্ট শ্রোতা)
v-on
Content (কম্পোনেন্টস বিষয়অবজেক্ট ওভাররাইড করে)
v-html
v-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>