IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> JavaScript知识库 -> vue3 -封装面包屑组件 -> 正文阅读

[JavaScript知识库]vue3 -封装面包屑组件

目的: 封装一个高复用的面包屑组件,适用于多级场景。认识 render 选项和 h 函数。

参考 element-ui 的面包屑组件
在这里插入图片描述

两个组件,xtx-bread 和 xtx-bread-item 才能完成动态展示

  • xtx-bread.vue

<script>
/*
  知识点:
    1. createVNode (h)函数,可以用于创建虚拟DOM (配合render函数渲染到页面中)
    2. render 函数返回的内容其实就是 template 模板的内容
    3. 组件实例.$slots.default()  获取默认插槽数据
*/
import { createVNode } from 'vue'
export default {
  name: 'XtxBread',
  // Vue3 的 render 形参其实是当前组件的实例,相当于Vue2的this
  render ({ $slots }) {
    // 获取默认插槽,过滤掉不符合规范的子项组件
    const slot = $slots.default().filter(item => item.type.name === 'XtxBreadItem' || item.type.name === 'Transition')
    // console.log('默认插槽', slot)

    const arr = []
    // 遍历默认插槽的虚拟DOM数组
    slot.forEach((item, index) => {
      arr.push(item)
      // 如果还没到最后一项,都动态追加一个 i 标签
      if (index < slot.length - 1) {
        // 创建个虚拟 i 标签
        const iVNode = createVNode('i', { class: 'iconfont icon-angle-right' })
        arr.push(iVNode)
      }
    })

    // h函数可以用于创建虚拟DOM
    //   语法:h('标签名称', 标签属性, 标签内容)
    const boxVNode = createVNode('div', { class: 'xtx-bread' }, arr)
    // console.log('虚拟DOM(对象)', box)
    // render 函数 return 出来的内容其实就是 template 的内容
    return boxVNode
  }
}
</script>

<style lang="less">
.xtx-bread {
  display: flex;
  padding: 25px 10px;
  &-item {
    a {
      color: #666;
      transition: all 0.4s;
      &:hover {
        color: @xtxColor;
      }
    }
  }
  i {
    font-size: 12px;
    margin-left: 5px;
    margin-right: 5px;
    line-height: 22px;
  }
}
</style>

  • xtx-bread-item.vue
<template>
  <div class="xtx-bread-item">
    <RouterLink v-if="to" :to="to"><slot /></RouterLink>
    <span v-else><slot /></span>
    <!-- <i class="iconfont icon-angle-right"></i> -->
  </div>
</template>

<script>
export default {
  name: 'XtxBreadItem',
  props: {
    to: {
      type: [String, Object]
    }
  }
}
</script>
  • 使用

首页 > 电器 > 空调

<!-- 面包屑 -->
<XtxBread>
    <XtxBreadItem to="/">首页</XtxBreadItem>
    <XtxBreadItem to="/category/1005000">电器</XtxBreadItem>
    <XtxBreadItem >空调</XtxBreadItem>
</XtxBread>
  JavaScript知识库 最新文章
ES6的相关知识点
react 函数式组件 & react其他一些总结
Vue基础超详细
前端JS也可以连点成线(Vue中运用 AntVG6)
Vue事件处理的基本使用
Vue后台项目的记录 (一)
前后端分离vue跨域,devServer配置proxy代理
TypeScript
初识vuex
vue项目安装包指令收集
上一篇文章      下一篇文章      查看所有文章
加:2021-08-17 01:25:52  更:2021-08-17 01:26:16 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/23 9:40:54-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码