我开始构建一个简单的实现,最后一个自定义组件如下所示:
data:image/s3,"s3://crabby-images/a7f59/a7f59761e93edd592efa7f62db64a2efaab0f242" alt=""
自动获取配置标题高度,然后当标题滚动时,可扩展标题缩减开始被切断的任何元素将会消失(并退回到再次出现空间的位置)。
创建组件
ionic g component super-header
修改super-header.ts
data:image/s3,"s3://crabby-images/b3fc3/b3fc3a549e8bd8983a835e7b0ed6a617b3e45974" alt=""
data:image/s3,"s3://crabby-images/7e59a/7e59a5d63212265e4d736b39135e158e6b77ef2f" alt=""
修改super-header.scss
data:image/s3,"s3://crabby-images/dd7a5/dd7a53f460199529974327ab61398e79f81acbe8" alt=""
修改super-header.html
data:image/s3,"s3://crabby-images/39429/39429d656b75ec79fc92ac9e319395d28a09ab78" alt=""
- scrollContent是我们在收听滚动事件的区域,以确定标题何时展开和缩小。
- OnInit组件初始化的时候监听滚动事件。
- 我们循环遍历组件所有子项,并检查元素的底部是否已被标题遮住。通过结合offsetTop与clientHeight每个元素的,我们能够制定出其中元件的底部实际上是相对于头部。
- 通过设置isHidden属性跟踪当前元件是否显示。出于性能原因,我们希望尽可能避免DOM更新。
- 通过domWrite是对dom的高效修改。
- 设置overflow属性在此处非常重要,否则组件不可见时,标题中的内容将会溢出到内容区域中
将组件添加到模板
home.html
data:image/s3,"s3://crabby-images/db983/db9839e5e51f1ee60db7d7c0d6ba19e2b4e6c261" alt=""
home.ts
data:image/s3,"s3://crabby-images/eebc3/eebc3ab74c9981c3d8f8bd9d6b29cb18c0bb127e" alt=""
- 重要的部分是我们在其中使用标签<super-header>,我们还设置了一个#content在该<ion-content>区域上调用的局部变量,并使用scrollContent输入将其传递到组件中。将fullscreen属性添加到该<ion-content>区域也很重要,以便标题正确显示。
- 我们对DOM进行高效的写入,因此它将在设备上运行良好,并且在应用程序中的任何位置也很容易配置和重用。
网友评论