您现在的位置是:网站首页> 编程资料编程资料
vue 面包屑导航组件封装_vue.js_
2023-05-24
317人已围观
简介 vue 面包屑导航组件封装_vue.js_
面包屑导航可以将浏览过的页面记录下来,方便很快速的跳转回某一个页面,本文介绍了几种自己封装面包屑组件的方式。
一、为什么需要面包屑?
当网页进行了多次跳转后,用户可能早就已经晕头转向了。作为程序猿的我们可能通过地址栏参数还可以分清楚当前处于哪一个位置,终归网页是要展示给用户。用户来使用的话,没有面包屑导航的话,可能就对网页产生了抵触心理,使用面包屑导航将每次跳转的页面记录下来,可以很好解决这一问题。
二、初级封装
1. 实现思路
- 准备页面结构和样式,需要用到字体图标 在
public目录下的index.html中引入cdn的字体图标资源
- 将需要外部传入的值定义为自定义属性
- 将外部写在标签内部的内容放置在默认插槽中
2. 代码演示
在src/components目录下新建bread-crumbs.vue文件,公用的组件放在这个目录下统一管理,文件名可自定义。
代码如下(示例):
在src/components目录下新建index.js文件,将封装好的全局组件进行注册
import BreadCrumbs from './bread-crumbs' export default { install (app) { app.component(BreadCrumbs.name, BreadCrumbs) } }在main.js中注册为插件
import { createApp } from 'vue' import App from './App.vue' import router from './router' import store from './store' // 导入并注册 import myUI from './components' createApp(App).use(store).use(router).use(myUI).mount('#app')3. 使用
传入公共组件需要的值 代码如下(示例):
4. 不足
只能满足基本需求,超过二级导航后就无法使用。
三、进阶封装
1. 实现思路
- 参考
elementUI面包屑组件代码
首页 活动管理 活动列表 活动详情
- 将每一个导航封装为一个组件
2. 代码演示
在上一步封装的基础上继续改进代码
代码如下(示例): 在src/component目录下新建bread-crumbs-item组件,文件名可以自定义。
还是在src/components目录下的index.js中注册为全局组件
import BreadCrumbs from './bread-crumbs' import BreadCrumbsItem from './bread-crumbs-item' export default { install (app) { app.component(BreadCrumbs.name, BreadCrumbs) app.component(BreadCrumbsItem .name, BreadCrumbsItem ) } }修改BreadCrumbs.vue中代码,将导航的每一项放置在默认插槽中
3. 使用
使用的时候,有多少个二级导航就使用几个BreadCrumbsItem 代码如下(示例):
4. 不足
在最后一个导航后面会有多余的一个>指示标识

四、高阶封装
1. 思路
终极版,使用render函数自己进行拼接创建。 createElement render
render选项与h函数指定组件显示的内容:
new Vue({选项})- el 选项,通过一个选择器找到容器,容器内容就是组件内容
- template 选项,
作为组件内容组件内容 - render选项,它是一个函数,函数回默认传人createElement的函数(h),这个函数用来创建结构,再render函数返回渲染为组件内容。它的优先级更高。
2. 代码演示
修改BreadCurmbsItem组件内的代码
修改BreadCrumbs.vue中的代码
代码示例(如下):
3. 使用
这个方式封装后,让全局组件的复用性更强了,强烈推荐使用

可以看到这样封装后,咱们自己封装的面包屑导航已经支持多级导航了。而且最后一个导航后面的>指示标识也没有了。
到此这篇关于vue 面包屑导航组件封装的文章就介绍到这了,更多相关vue 面包屑导航内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!
相关内容
- vue el-select绑定对象时,回显内容不正确,始终是最后一项的解决_vue.js_
- Vue动态数据实现 el-select 多级联动、数据回显方式_vue.js_
- JS中ESModule和commonjs介绍及使用区别_javascript技巧_
- Vue3+Canvas实现简易的贪吃蛇游戏_vue.js_
- JS SVG获取验证码的玩法示例_JavaScript_
- JavaScript利用normalizr实现复杂数据转换_javascript技巧_
- node+js搭建时间服务器的思路详解_node.js_
- 一文教你学会在Vue3中自定义指令_vue.js_
- JS递归遍历查询是否有权限示例详解_JavaScript_
- JavaScript三大重点同步异步与作用域和闭包及原型和原型链详解_javascript技巧_
