基于angular6.0实现的一个组件懒加载功能示例

网友投稿 230 2023-02-08


基于angular6.0实现的一个组件懒加载功能示例

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

项目地址github

安装

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 {}

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 {

return LazyTestComponent;

}

}


版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:vue 组件高级用法实例详解
下一篇:Koa项目搭建过程详细记录
相关文章

 发表评论

暂时没有评论,来抢沙发吧~