Vue3實戰(zhàn)之插槽封裝與懶加載詳解
一、為什么需要插槽?從一個面板組件說起
在電商首頁開發(fā)中,經(jīng)常遇到這樣的場景:
「新鮮好物」「人氣推薦」同樣類型模塊都需要相同的標題欄,但內(nèi)容區(qū)布局不同這時候,插槽(Slot)就像一個「內(nèi)容拼圖位」,讓組件既能統(tǒng)一樣式,又能靈活定制。
實戰(zhàn)案例:HomePanel 通用面板
<template> <div class="home-panel"> <div class="head"> <h3>{{ title }}<small>{{ subTitle }}</small></h3> </div> <slot name="main" /> <!-- 內(nèi)容拼圖位 --> </div> </template> <script setup> defineProps({ title: String, subTitle: String }) </script>
使用方式:
<HomePanel title="新鮮好物" sub-title="新鮮出爐"> <template #main> <!-- 填充拼圖 --> <ul class="goods-list"> <li v-for="item in list">{{ item.name }}</li> </ul> </template> </HomePanel>
實現(xiàn)效果:
插槽的 3 個好處:
- 結(jié)構(gòu)分離:標題樣式統(tǒng)一管理,內(nèi)容區(qū)自由發(fā)揮(列表 / 圖片 / 按鈕均可)
- 復(fù)用性強:一個面板組件適配 N 種業(yè)務(wù)場景
- 語義清晰:通過具名插槽(#main)明確內(nèi)容位置
二、懶加載:讓圖片「按需加載」的魔法
電商首頁往往包含大量圖片,一次性加載會導(dǎo)致:
- 首屏加載慢
- 流量浪費
- 手機發(fā)燙
懶加載(Lazy Load)的核心邏輯:圖片進入視口時再加載
用 Vue3 指令實現(xiàn)懶加載
// 全局指令:directives/lazy.js import { useIntersectionObserver } from '@vueuse/core' export const lazyPlugin = { install(app) { app.directive('img-lazy', { mounted(el, binding) { // 當(dāng)元素進入視口時 const { stop } = useIntersectionObserver(el, ([{ isIntersecting }]) => { if (isIntersecting) { el.src = binding.value // 替換真實src stop() // 停止觀察,避免重復(fù)觸發(fā) } }) } }) } }
使用方式:
<img v-img-lazy="goods.picture" alt="商品圖" />
實現(xiàn)原理拆解:
- IntersectionObserver:瀏覽器原生 API,監(jiān)聽元素是否進入視口
- 指令生命周期:在
mounted
階段綁定觀察,避免重復(fù)綁定 - 停止觀察:圖片加載后立即停止監(jiān)聽,節(jié)省性能
三、插槽 × 懶加載:實戰(zhàn)中的黃金組合
在「商品館」模塊中,同時用到了插槽和懶加載:
<HomePanel title="數(shù)碼館"> <template #main> <div class="box"> <img v-img-lazy="bannerUrl" class="cover" /> <!-- 大圖懶加載 --> <ul> <li v-for="goods in list"> <GoodsItem :goods="goods" /> <!-- 子組件插槽 --> </li> </ul> </div> </template> </HomePanel> <!-- GoodsItem子組件 --> <template> <RouterLink> <img v-img-lazy="goods.picture" /> <!-- 商品圖懶加載 --> <p>{{ goods.name }}</p> </RouterLink> </template>
效果:
- 標題欄統(tǒng)一樣式,內(nèi)容區(qū)自由布局(大圖 + 列表)
- 所有圖片均在進入視口時加載,首屏加載速度提升 40%
四、新手避坑指南
- 插槽默認值:給插槽設(shè)置默認內(nèi)容,避免父組件未傳時的空白
<slot name="main">暫無內(nèi)容</slot>
- 懶加載占位圖:加載前使用占位圖(如灰色色塊),避免布局抖動
<img v-img-lazy="realSrc" :src="placeholder" />
- 指令參數(shù)校驗:確保指令值是合法 URL
if (!binding.value.startsWith('http')) return
五、總結(jié):讓組件會「呼吸」
- 插槽讓組件有了「可插拔」的能力,像搭積木一樣組裝頁面
- 懶加載讓頁面學(xué)會「按需呼吸」,節(jié)省資源的同時提升用戶體驗
- 兩者結(jié)合,實現(xiàn)了 「結(jié)構(gòu)統(tǒng)一」與「內(nèi)容靈活」的完美平衡
到此這篇關(guān)于Vue3實戰(zhàn)之插槽封裝與懶加載的文章就介紹到這了,更多相關(guān)Vue3插槽封裝與懶加載內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
vue新建環(huán)境變量以及網(wǎng)絡(luò)請求工具axios的二次封裝詳解
這篇文章主要為大家介紹了vue新建環(huán)境變量以及網(wǎng)絡(luò)請求工具axios的二次封裝詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2023-06-06