大家好,我是大澈!
本文约3100+字,整篇阅读大约需要5分钟。
本文主要内容分三部分,第一部分是需求分析,第二部分是实现步骤,第三部分是问题详解。
如果您只需要解决问题,请阅读第一、二部分即可。
如果您有更多时间,进一步学习问题相关知识点,请阅读至第三部分。
实现级联菜单效果,点击一级菜单某一项,就会加载出对应的二级菜单内容,点击二级菜单某一项,就会加载出对应的三级菜单内容,以此类推,最后一级为五级菜单。
对于加载而言,必须是懒加载效果,即点击菜单某一项时,才会真正去请求加载对应的下一级菜单内容。
对于菜单最后一级内容,要插入一个输入框,在输入框内,用户可以任意输入版本号,并且要求输入框不可被选中。
当然,我们的正题是数据的懒加载,级联菜单中插入不可被选中的输入框实现算是附加内容了。
在项目中,我们使用数据的懒加载,会有如下好处:
了解了这些好处之后,再就是要了解数据懒加载的应用场景。
这部分比较有用,所以多叙述一些。
数据懒加载在以下场景中特别有用:
上述场景在此部分只做简单描述,如果你有空余时间,各个场景具体代码实例请见第三部分总结。
我们这次的需求实现,就是符合第1条场景。
当选中某一级时,动态加载该级下的选项。
通过lazy开启动态加载,并通过lazyload方法来设置加载数据源。
模板代码:
逻辑代码:
通过插槽和条件判断,在级联面板中插入输入框,其中data.label为节点对象的名称。
通过@click.stop阻止事件冒泡、宽度为父元素的100%、以及清除级联面板组件一些默认样式,实现了输入框不可被选中的效果。
模版代码:
{{ data.label }}
{{ data.label }}
样式代码:
长列表或分页数据懒加载:
-
{{ item.name }}
- Loading...
图片懒加载:
条件性数据懒加载:
路由懒加载(基于 Vue Router):
const Home = () => import('./components/Home.vue');
const About = () => import('./components/About.vue');
const Contact = () => import('./components/Contact.vue');
const routes = [
{ path: '/home', component: Home },
{ path: '/about', component: About },
{ path: '/contact', component: Contact },
];
const router = new VueRouter({
routes,
});
异步加载模块(基于 import() 动态导入语法):