• 注册
当前位置:1313e > 默认分类 >正文

Ionic如何创建自定义展开标题组件

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/inforstack/article/details/77806847

自定义组件

我开始构建一个简单的实现,最后一个自定义组件如下所示:


自动获取标题高度,然后当标题滚动时,可扩展标题缩减开始被切断的任何元素将会消失(并退回到再次出现空间的位置)。

创建组件

ionic g component super-header

修改super-header.ts 

oldHeight: number;newHeight: number;@Input() scrollContent: any;constructor(private zone: NgZone, private rend2: Renderer2, private el: ElementRef) {}ngOnInit(): void {if (!this.oldHeight) {//获取标签高度this.oldHeight = this.el.nativeElement.clientHeight;}this.zone.run(() => {//监听滚动事件this.scrollContent.ionScroll.subscribe((ev) => {ev.domWrite(() => {//减掉滚动的高度this.newHeight = this.oldHeight - ev.scrollTop;if (this.newHeight < 0) {//滚动高度超出标签高度设为0px (隐藏标签)this.newHeight = 0;}this.handlerEl();});});});}handlerEl() {//设置标签高度this.rend2.setStyle(this.el.nativeElement, 'height', this.newHeight + 'px');//查找子标签let subs = this.el.nativeElement.children;//设置显示隐藏效果for (let sub of subs) {let totalHeight = sub.offsetTop + sub.clientHeight;if (totalHeight > this.newHeight && !sub.isHidden) {sub.isHidden = true;this.rend2.setStyle(sub, 'opacity', '0.8');} else if (totalHeight <= this.newHeight && sub.isHidden) {sub.isHidden = false;this.rend2.setStyle(sub, 'opacity', '1');}}
修改super-header.scss

super-header {display: block;transform: translate3d(0, 0, 0);transition: 500ms ease-out;background-color: map-get($colors, primary) !important;overflow: hidden;
}
修改super-header.html
  • scrollContent是我们在收听滚动事件的区域,以确定标题何时展开和缩小。
  • OnInit组件初始化的时候监听滚动事件。
  • 我们循环遍历组件所有子项,并检查元素的底部是否已被标题遮住。通过结合offsetTop与clientHeight每个元素的,我们能够制定出其中元件的底部实际上是相对于头部。
  • 通过设置isHidden属性跟踪当前元件是否显示。出于性能原因,我们希望尽可能避免DOM更新。
  • 通过domWrite是对dom的高效修改。
  • 设置overflow属性在此处非常重要,否则组件不可见时,标题中的内容将会溢出到内容区域中。

将组件添加到模板

Home
{{item}}

重要的部分是我们在其中使用标签,我们还设置了一个#content在该区域上调用的局部变量,并使用scrollContent输入将其传递到组件中。将fullscreen属性添加到该区域也很重要,以便标题正确显示。

我们对DOM进行高效的写入,因此它将在设备上运行良好,并且在应用程序中的任何位置也很容易配置和重用。

源码分享地址



本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 162202241@qq.com 举报,一经查实,本站将立刻删除。

最新评论

欢迎您发表评论:

请登录之后再进行评论

登录
相关推荐