1200字范文,内容丰富有趣,写作的好帮手!
1200字范文 > 基于 angular 实现的一个【组件懒加载功能】

基于 angular 实现的一个【组件懒加载功能】

时间:2023-08-30 03:37:55

相关推荐

基于 angular 实现的一个【组件懒加载功能】

给予 angular6.0 实现的一个【组件懒加载功能】

我们常常会遇到这样一个问题,当我们使用一个第三方控件库的时候,我们只用到了其中 1 个或某几个组件,会连带一大堆无用的东西,造成体积臃肿不堪。又或者首页用到的组件较多,首页加载速度缓慢,这个时候,我们或许需要加载用户可视范围内用到的组件,随着用户的浏览下拉,我们再去加载这些组件,渐进式加载,渐进式体验,这个时候你或许就用到了本工具所实现的功能。或者一个页面的某些不重要区域,比如第三方广告又或者不重要的元素,可以采用懒加载懒渲染,降低用户首屏等待时间。一切都在用户不知不觉中进行。大大增加用户体验,特别是中大型项目,优化必备!

从1.0.1开始,我们做了简化处理,不必单独配置,使用时设置路由名为选择器即可!

版本

v1.0.2v1.0.1v1.0.0

安装

yarn add iwe7-lazy-load复制代码

使用

import { Iwe7LazyLoadModule, LazyComponentsInterface } from 'iwe7-lazy-load';// 用到的懒加载组件let lazyComponentsModule: LazyComponentsInterface[] = [{// 组件的selectorpath: '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({declarations: [LazyTestComponent],entryComponents: [LazyTestComponent]})export class LazyTestModule extends LazyComponentModuleBase {getComponentByName(key: string): Type<any> {return LazyTestComponent;}}复制代码

小结

希望对大家有所帮助

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。