Built-in Special Elements
Components নয়
<component>
, <slot>
এবং <template>
হল কম্পোনেন্ট-এর মতো বৈশিষ্ট্য এবং টেমপ্লেট সিনট্যাক্সের অংশ। এগুলি সত্য কম্পোনেন্ট নয় এবং টেমপ্লেট সংকলনের সময় কম্পাইল করা হয়। যেমন, তারা প্রচলিতভাবে টেমপ্লেটে ছোট হাতের অক্ষর দিয়ে লেখা হয়।
<component>
গতিশীল কম্পোনেন্ট বা কম্পোনেন্ট রেন্ডার করার জন্য একটি "meta component"।
Props
tsinterface DynamicComponentProps { is: string | Component }
** বিস্তারিত**
রেন্ডার করার জন্য প্রকৃত কম্পোনেন্ট
is
প্রপ দ্বারা নির্ধারিত হয়।যখন
is
একটি স্ট্রিং হয়, এটি হয় একটি HTML ট্যাগ নাম বা কোনো কম্পোনেন্টস নিবন্ধিত নাম হতে পারে।বিকল্পভাবে,
is
একটি কম্পোনেন্টস সংজ্ঞার সাথে সরাসরি আবদ্ধ হতে পারে।
উদাহরণ
নিবন্ধিত নাম দ্বারা কম্পোনেন্ট রেন্ডারিং (Options API):
vue<script> import Foo from './Foo.vue' import Bar from './Bar.vue' export default { components: { Foo, Bar }, data() { return { view: 'Foo' } } } </script> <template> <component :is="view" /> </template>
সংজ্ঞা অনুসারে কম্পোনেন্ট রেন্ডারিং (Composition API with
<script setup>
):vue<script setup> import Foo from './Foo.vue' import Bar from './Bar.vue' </script> <template> <component :is="Math.random() > 0.5 ? Foo : Bar" /> </template>
Rendering HTML elements:
template<component :is="href ? 'a' : 'span'"></component>
বিল্ট-ইন কম্পোনেন্ট সবই
is
-এ পাস করা যেতে পারে, কিন্তু আপনি যদি সেগুলি নাম দিয়ে পাস করতে চান তাহলে আপনাকে অবশ্যই সেগুলি নিবন্ধন করতে হবে৷ উদাহরণ স্বরূপ:vue<script> import { Transition, TransitionGroup } from 'vue' export default { components: { Transition, TransitionGroup } } </script> <template> <component :is="isGroup ? 'TransitionGroup' : 'Transition'"> ... </component> </template>
আপনি যদি কম্পোনেন্টটিকে এর নামের পরিবর্তে
is
-এ পাস করেন তাহলে নিবন্ধনের প্রয়োজন নেই, যেমন<script setup>
-এ।যদি
v-model
একটি<component>
ট্যাগে ব্যবহার করা হয়, তাহলে টেমপ্লেট কম্পাইলার এটিকে একটিmodelValue
প্রপ এবংupdate:modelValue
ইভেন্ট লিসেনারে প্রসারিত করবে, অনেকটা অন্য কোনো কম্পোনেন্টস মতো। যাইহোক, এটি নেটিভ HTML কম্পোনেন্টস সাথে সামঞ্জস্যপূর্ণ হবে না, যেমন<input>
বা<select>
। ফলস্বরূপ, গতিশীলভাবে তৈরি স্থানীয় কম্পোনেন্টস সাথেv-model
ব্যবহার করা কাজ করবে না:vue<script setup> import { ref } from 'vue' const tag = ref('input') const username = ref('') </script> <template> <!-- This won't work as 'input' is a native HTML element --> <component :is="tag" v-model="username" /> </template>
অনুশীলনে, এই এজ কেসটি সাধারণ নয় কারণ নেটিভ ফর্ম ক্ষেত্রগুলি সাধারণত বাস্তব অ্যাপ্লিকেশনগুলিতে কম্পোনেন্টগুলিতে মোড়ানো থাকে। আপনি যদি সরাসরি একটি নেটিভ এলিমেন্ট ব্যবহার করতে চান তাহলে আপনি v-model
কে একটি অ্যাট্রিবিউট এবং ইভেন্টে ম্যানুয়ালি বিভক্ত করতে পারেন।
- আরো দেখুন Dynamic Components
<slot>
টেমপ্লেটগুলিতে স্লট সামগ্রী আউটলেটগুলিকে বোঝায়।
Props
tsinterface SlotProps { /** * Any props passed to <slot> to passed as arguments * for scoped slots */ [key: string]: any /** * Reserved for specifying slot name. */ name?: string }
** বিস্তারিত**
<slot>
কম্পোনেন্টটি একটি স্লটের নাম নির্দিষ্ট করতেname
বৈশিষ্ট্য ব্যবহার করতে পারে। যখন কোনোname
নির্দিষ্ট করা না থাকে, এটি ডিফল্ট স্লট রেন্ডার করবে। স্লট কম্পোনেন্টে পাস করা অতিরিক্ত বৈশিষ্ট্যগুলি প্যারেন্টে সংজ্ঞায়িত স্কোপড স্লটে স্লট প্রপ হিসাবে পাস করা হবে।কম্পোনেন্টটি নিজেই এর মিলিত স্লট সামগ্রী দ্বারা প্রতিস্থাপিত হবে।
<slot>
Vue টেমপ্লেটের কম্পোনেন্টগুলি জাভাস্ক্রিপ্টে কম্পাইল করা হয়েছে, তাই সেগুলিকে বিভ্রান্ত করা যাবে না native<slot>
elements.আরো দেখুন Component - Slots
<template>
<template>
ট্যাগটি প্লেসহোল্ডার হিসেবে ব্যবহার করা হয় যখন আমরা DOM-এ কোনো কম্পোনেন্ট রেন্ডার না করে বিল্ট-ইন নির্দেশিকা ব্যবহার করতে চাই।
** বিস্তারিত**
<template>
এর জন্য বিশেষ হ্যান্ডলিং শুধুমাত্র তখনই ট্রিগার হয় যদি এটি এই নির্দেশাবলীর একটির সাথে ব্যবহার করা হয়:v-if
,v-else-if
, orv-else
v-for
v-slot
যদি এই নির্দেশাবলীর কোনোটিই উপস্থিত না থাকে তবে এটি একটি নেটিভ
<template>
কম্পোনেন্ট হিসেবে রেন্ডার করা হবে।একটি
<template>
একটিv-for
সহ একটিকী
বৈশিষ্ট্য থাকতে পারে। অন্যান্য সমস্ত বৈশিষ্ট্য এবং নির্দেশ বাতিল করা হবে, কারণ সেগুলি সংশ্লিষ্ট কম্পোনেন্ট ছাড়া অর্থপূর্ণ নয়৷একক-ফাইল কম্পোনেন্টগুলি সম্পূর্ণ টেমপ্লেটটি মোড়ানোর জন্য একটি শীর্ষ-স্তরের
<template>
ট্যাগ ব্যবহার করে। সেই ব্যবহার উপরে বর্ণিত<template>
ব্যবহার থেকে আলাদা। সেই শীর্ষ-স্তরের ট্যাগটি নিজেই টেমপ্লেটের অংশ নয় এবং টেমপ্লেট সিনট্যাক্স সমর্থন করে না, যেমন নির্দেশাবলী।আরো দেখুন