基于angular6.0实现的一个组件懒加载功能示例
- 作者: Garde丶mafille
- 来源: 51数据库
- 2021-08-17
我们常常会遇到这样一个问题,当我们使用一个第三方控件库的时候,我们只用到了其中 1 个或某几个组件,会连带一大堆无用的东西,造成体积臃肿不堪。又或者首页用到的组件较多,首页加载速度缓慢,这个时候,我们或许需要加载用户可视范围内用到的组件,随着用户的浏览下拉,我们再去加载这些组件,渐进式加载,渐进式体验,这个时候你或许就用到了本工具所实现的功能。或者一个页面的某些不重要区域,比如第三方广告又或者不重要的元素,可以采用懒加载懒渲染,降低用户首屏等待时间。一切都在用户不知不觉中进行。大大增加用户体验,特别是中大型项目,优化必备!
安装
yarn add iwe7-lazy-load
使用
import { iwe7lazyloadmodule, lazycomponentsinterface } from 'iwe7-lazy-load';
// 用到的懒加载组件
let lazycomponentsmodule: lazycomponentsinterface[] = [
{
// 组件的selector
path: 'lazy-test',
// 组件的相对地址
loadchildren: './lazy-test/lazy-test.module#lazytestmodule'
}
];
@ngmodule({
imports: [iwe7lazyloadmodule.forroot(lazycomponentsmodule)],
// 注意加上这些
schemas: [custom_elements_schema, no_errors_schema]
})
export class appmodule {}
<div #ele> <lazy-test></lazy-test> </div>
import { lazyloaderservice } from 'iwe7-lazy-load';
@viewchild('ele') ele: elementref;
constructor(
public lazyloader: lazyloaderservice,
public view: viewcontainerref
) {}
ngoninit() {
// 开始渲染懒组件
this.lazyloader.init(this.ele.nativeelement, this.view);
}
定义懒加载组件 demo
import { lazycomponentmodulebase } from 'iwe7-lazy-load';
@component({
selector: 'lazy-test',
template: ` i am a lazy`
})
export class lazytestcomponent {}
@ngmodule({
imports: [
routermodule.forchild([{
path: '',
component: lazytestcomponent
}])
],
declarations: [lazytestcomponent]
})
export class lazytestmodule extends lazycomponentmodulebase {
getcomponentbyname(key: string): type<any> {
return lazytestcomponent;
}
}
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
推荐阅读
热点文章
Angular中响应式表单的三种更新值方法详析
7
Angularjs实现下拉框联动的示例代码
7
详解AngularJS跨页面传值(ui-router)
2
详解AngularJS1.x学习directive 中‘& ’‘=’ ‘@’符号的区别使用
3
angular2路由切换改变页面title的示例代码
4
Angular2 组件间通过@Input @Output通讯示例
5
Angularjs中ng-repeat的简单实例
3
AngularJS 中ui-view传参的实例详解
4
浅谈Angular路由守卫
4
详解基于Angular4+ server render(服务端渲染)开发教程
4
