Media is too big
VIEW IN TELEGRAM
ویو 3.5.0 منتشر شد (ویدیو دوبله شده)
بهینه سازیهای زیادی در واکنشگرایی انجام شده است،
پشتیبانی از وب کامپوننتها بهبود یافته است،
امکان دیستراکچر کردن propsها اضافه شده است،
استفاده از Teleport به تعویق افتاده (defer) است، useTemplateRef()، app.onUnmount()، useId() و بسیاری از ویژگیها و رفع باگهای کوچک دیگر اضافه شدهاند.
🔗https://blog.vuejs.org/posts/vue-3-5
🔗 https://github.com/vuejs/core/blob/main/CHANGELOG.md
#️⃣#tip #dub #vue
👥@IR_javascript_group
🆔@IR_javascript
بهینه سازیهای زیادی در واکنشگرایی انجام شده است،
پشتیبانی از وب کامپوننتها بهبود یافته است،
امکان دیستراکچر کردن propsها اضافه شده است،
استفاده از Teleport به تعویق افتاده (defer) است، useTemplateRef()، app.onUnmount()، useId() و بسیاری از ویژگیها و رفع باگهای کوچک دیگر اضافه شدهاند.
🔗https://blog.vuejs.org/posts/vue-3-5
🔗 https://github.com/vuejs/core/blob/main/CHANGELOG.md
#️⃣#tip #dub #vue
👥@IR_javascript_group
🆔@IR_javascript
❤2
نمونهای از "نشت" استایلها در Vue 3 با استفاده از Scoped Styles
در این مثال، دو کامپوننت A.vue و B.vue هر دو از کلاسی با نام مشابه a استفاده میکنند. این مسئله حتی با وجود استفاده از scoped styles میتواند منجر به نشت استایلها شود.
برای مشاهده و تست این مسئله میتوانید از لینک زیر استفاده کنید
راهحل: نامگذاری معنایی کلاسها
برای جلوگیری از این نوع تداخلات، بهتر است نام کلاسها به گونهای انتخاب شوند که معنایی باشند و وابستگی آنها به کامپوننت مربوطه مشخص باشد.
🔗https://play.vuejs.org/#eNqdUj1PwzAQ/SvWzSgZYCoFKaAOMAACRi/GuQYXx7Z8Timq+t85O7S0AlWIKfH7sN7d8xqaEKrlgDCBKeloQhKEaQiX0pk++JhEI+bR90JCVTdZKeFcOumm9ShnIR8S9sGqhHyatmYptFVEFxJeJDAkxAGovkCGG1GPfM2CbN59927kI6UPi4K0D9gyUimxzjbtrY8T0UVEx6k2JVaWsgZOILHBzU1XLcg7nrB4JGjfB2Mx3odkvCMJk/G2zClr/fttwVIc8GSL61fUb7/gC1plTMJDRMK45PXsuKRih2mkZ093uOL/Hdn7drCsPkI+Ink75Iyj7GpwLcfe05W0N6Un47pnmq0SOtoOlYNm5aboJXB510dG/457Wp0VH2+Ut1ha//E+/tZ/rtoI1YuI7f+6ZeNhs7D5BMkN50M=
#️⃣#tip #vue
👥@IR_javascript_group
🆔@IR_javascript
<!-- A.vue -->
<div class="a" />
<!-- B.vue -->
<div class="b">
<div class="a">
<A /> <!-- اوه، مشکل! -->
</div>
</div>
در این مثال، دو کامپوننت A.vue و B.vue هر دو از کلاسی با نام مشابه a استفاده میکنند. این مسئله حتی با وجود استفاده از scoped styles میتواند منجر به نشت استایلها شود.
برای مشاهده و تست این مسئله میتوانید از لینک زیر استفاده کنید
راهحل: نامگذاری معنایی کلاسها
برای جلوگیری از این نوع تداخلات، بهتر است نام کلاسها به گونهای انتخاب شوند که معنایی باشند و وابستگی آنها به کامپوننت مربوطه مشخص باشد.
🔗https://play.vuejs.org/#eNqdUj1PwzAQ/SvWzSgZYCoFKaAOMAACRi/GuQYXx7Z8Timq+t85O7S0AlWIKfH7sN7d8xqaEKrlgDCBKeloQhKEaQiX0pk++JhEI+bR90JCVTdZKeFcOumm9ShnIR8S9sGqhHyatmYptFVEFxJeJDAkxAGovkCGG1GPfM2CbN59927kI6UPi4K0D9gyUimxzjbtrY8T0UVEx6k2JVaWsgZOILHBzU1XLcg7nrB4JGjfB2Mx3odkvCMJk/G2zClr/fttwVIc8GSL61fUb7/gC1plTMJDRMK45PXsuKRih2mkZ093uOL/Hdn7drCsPkI+Ink75Iyj7GpwLcfe05W0N6Un47pnmq0SOtoOlYNm5aboJXB510dG/457Wp0VH2+Ut1ha//E+/tZ/rtoI1YuI7f+6ZeNhs7D5BMkN50M=
#️⃣#tip #vue
👥@IR_javascript_group
🆔@IR_javascript
👍1
// useUserService.ts
function isAuthenticated() {
return !!user.value;
}
// کامپوننت A
<script>
const { isAuthenticated } = useUserService();
</script>
<template>
<p v-if="isAuthenticated()">سلام</p>
</template>
توابع در Vue رفتار متفاوتی از توابع معمولی دارند.
در این مثال، تابع
isAuthenticated() مانند یک computed عمل میکند و هر بار که مقدار user تغییر کند یا کامپوننت A دوباره رندر شود، فراخوانی خواهد شد.این اتفاق به این دلیل میافتد که Vue تمام وابستگیهای واکنشپذیر را درون بدنهی تابع شناسایی کرده و هر زمان که یکی از آنها تغییر کند، کامپوننت را دوباره رندر میکند.
بنابراین، تفاوت زیادی در استفاده از یک تابع به جای
computed وجود ندارد. اما اگر داخل تابع منطق پیچیدهتری وجود داشته باشد، بهتر است از computed استفاده کنید، زیرا فقط زمانی که وابستگیهای آن تغییر کنند، محاسبه مجدد میشود، در حالی که تابع در هر رندر اجرا میشود.#️⃣#tip #vue
👥@IR_javascript_group
🆔@IR_javascript
❤1
اگر صفحهای را از طریق
از طریق watch:
از طریق هوک روتر
روش دوم این امکان را فراهم میآورد که از
#️⃣#tip #vue
👥@IR_javascript_group
🆔@IR_javascript
<router-view> نمایش میدهید که شامل پارامترهای مسیری (مانند محصولات، کاتالوگها یا کاربران از طریق شناسه) است و باید در صورت تغییر پارامتر، اطلاعات جدیدی بارگذاری کنید، یعنی باید تغییرات پارامتر را پیگیری کنید، این کار را میتوان به دو روش انجام داد.از طریق watch:
watch(
() => route.params.id,
async () => {
userData.value = await fetchUser(to.params.id);
},
{ immediate: true }
);
از طریق هوک روتر
onBeforeRouteUpdate:import { onBeforeRouteUpdate } from 'vue-router'
onBeforeRouteUpdate(async (to, from) => {
if (to.params.id !== from.params.id) {
userData.value = await fetchUser(to.params.id);
}
})روش دوم این امکان را فراهم میآورد که از
onBeforeRouteLeave نیز استفاده کنید، اگر به هر دلیلی نیاز باشد.#️⃣#tip #vue
👥@IR_javascript_group
🆔@IR_javascript
👍1
Media is too big
VIEW IN TELEGRAM
حالت بخار (Vapor Mode) در Vue.js یک استراتژی کامپایل جایگزین است که برای بهبود عملکرد برنامههای Vue.js طراحی شده است. این حالت به جای استفاده از Virtual DOM (VDOM)، کامپوننتها را مستقیماً به HTML تبدیل میکند
vapor mode در vue 3.6 اضافه خواهد شد
#️⃣#tip #vue #dub
👥@IR_javascript_group
🆔@IR_javascript
vapor mode در vue 3.6 اضافه خواهد شد
#️⃣#tip #vue #dub
👥@IR_javascript_group
🆔@IR_javascript
🔥2🤯1
برای کسانی که نمیدانند، در VS Code (با افزونهی Volar) یک فرمان کاربردی وجود دارد که امکان تقسیم یک فایل به دو پنجره بر اساس بخشهای SFC را فراهم میکند.
#️⃣#tool #vue
👥@IR_javascript_group
🆔@IR_javascript
#️⃣#tool #vue
👥@IR_javascript_group
🆔@IR_javascript
👍1
ویدیو دوبله شده در مورد بهینهسازی عملکرد Vue [+لینک]
عملکرد بهینه یکی از عوامل کلیدی در اپلیکیشنهای مدرن تحت وب است. عملکرد ضعیف منجر به کاهش تعامل کاربران، کاهش نرخ تبدیل و در نهایت از دست دادن فرصتهای تجاری میشود. این دوره به شما کمک میکند تا:
زمان بارگذاری و عملکرد اجرایی اپلیکیشن Vue.js خود را بهطور چشمگیری بهبود دهید.
تکنیکهای پیشرفته بهینهسازی که توسط متخصصان صنعت استفاده میشود را اجرا کنید.
مشکلات عملکردی را بهصورت کارآمد اشکالزدایی و برطرف کنید.
تصمیمات معماری آگاهانهای اتخاذ کنید که بر سرعت برنامه تأثیر میگذارد.
تجربهای استثنایی برای کاربران از طریق بهینهسازی عملکرد ارائه دهید.
به ما بپیوندید و با تسلط بر بهینهسازی عملکرد Vue.js، اپلیکیشنهای خود را به سطحی جدید از سرعت و کارایی برسانید.
🔗https://www.aparat.com/v/tdvpkja?playlist=17549421
#️⃣#tip #dub #vue
👥@IR_javascript_group
🆔@IR_javascript
عملکرد بهینه یکی از عوامل کلیدی در اپلیکیشنهای مدرن تحت وب است. عملکرد ضعیف منجر به کاهش تعامل کاربران، کاهش نرخ تبدیل و در نهایت از دست دادن فرصتهای تجاری میشود. این دوره به شما کمک میکند تا:
زمان بارگذاری و عملکرد اجرایی اپلیکیشن Vue.js خود را بهطور چشمگیری بهبود دهید.
تکنیکهای پیشرفته بهینهسازی که توسط متخصصان صنعت استفاده میشود را اجرا کنید.
مشکلات عملکردی را بهصورت کارآمد اشکالزدایی و برطرف کنید.
تصمیمات معماری آگاهانهای اتخاذ کنید که بر سرعت برنامه تأثیر میگذارد.
تجربهای استثنایی برای کاربران از طریق بهینهسازی عملکرد ارائه دهید.
به ما بپیوندید و با تسلط بر بهینهسازی عملکرد Vue.js، اپلیکیشنهای خود را به سطحی جدید از سرعت و کارایی برسانید.
🔗https://www.aparat.com/v/tdvpkja?playlist=17549421
#️⃣#tip #dub #vue
👥@IR_javascript_group
🆔@IR_javascript
👍4
در CSS**، قابلیت **@scope برای محدود کردن دامنهی اعمال استایلها معرفی شده است:
### 🔹 مثال:
این ویژگی میتواند در برخی موارد مفید باشد، اما جایگزین کاملی برای Vue Scoped Styles نیست.
### 🔸 تفاوت با Vue Scoped:
- در Vue، اگر یک کامپوننت را در یک لیست رندر کنید، هر نمونهی کامپوننت یک data-attribute منحصربهفرد دارد که استایلهای آن را جدا نگه میدارد.
- اما در @scope**، دامنهی استایلها ممکن است **با سایر نمونهها ترکیب شود و یکپارچگی آن حفظ نشود.
با این حال، @scope برای موارد ساده و Vanilla CSS یک قابلیت کاربردی و مفید محسوب میشود. 🎨
#️⃣#tip #vue
👥@IR_javascript_group
🆔@IR_javascript
### 🔹 مثال:
<template>
<div class="box">
<button class="button">Click me</button>
</div>
</template>
<style>
@scope (.box) {
.button {
color: red;
}
}
</style>
این ویژگی میتواند در برخی موارد مفید باشد، اما جایگزین کاملی برای Vue Scoped Styles نیست.
### 🔸 تفاوت با Vue Scoped:
- در Vue، اگر یک کامپوننت را در یک لیست رندر کنید، هر نمونهی کامپوننت یک data-attribute منحصربهفرد دارد که استایلهای آن را جدا نگه میدارد.
- اما در @scope**، دامنهی استایلها ممکن است **با سایر نمونهها ترکیب شود و یکپارچگی آن حفظ نشود.
با این حال، @scope برای موارد ساده و Vanilla CSS یک قابلیت کاربردی و مفید محسوب میشود. 🎨
#️⃣#tip #vue
👥@IR_javascript_group
🆔@IR_javascript
🔥2
اگر یک آرایه دارید که هر عنصر آن شامل یک مقدار computed است، بهتر است یک مقدار computed برای کل آرایه ایجاد کنید تا اینکه برای هر عنصر جداگانه یک مقدار computed داشته باشید.
### نمونه نامناسب
### نمونه بهینه
با این روش، محاسبات بهینهتر انجام میشود و از ایجاد چندین مقدار computed غیرضروری جلوگیری خواهد شد.
#️⃣#tip #vue
👥@IR_javascript_group
🆔@IR_javascript
### نمونه نامناسب
const rows = productRows.map(row => ({
...row,
total: computed(() => row.price * row.qty),
}));### نمونه بهینه
const computedRows = computed(() =>
productRows.map(row => ({
...row,
total: row.price * row.qty,
}))
);
با این روش، محاسبات بهینهتر انجام میشود و از ایجاد چندین مقدار computed غیرضروری جلوگیری خواهد شد.
#️⃣#tip #vue
👥@IR_javascript_group
🆔@IR_javascript
👍1