博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Ionic如何创建自定义展开标题组件
阅读量:6274 次
发布时间:2019-06-22

本文共 2423 字,大约阅读时间需要 8 分钟。

版权声明:本文为博主原创文章,未经博主允许不得转载。 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}}
重要的部分是我们在其中使用标签<super-header>,我们还设置了一个#content在该<ion-content>区域上调用的局部变量,并使用scrollContent输入将其传递到组件中。将fullscreen属性添加到该<ion-content>区域也很重要,以便标题正确显示。

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

你可能感兴趣的文章
python2.7 之centos7 安装 pip, Scrapy
查看>>
机智云开源框架初始化顺序
查看>>
Spark修炼之道(进阶篇)——Spark入门到精通:第五节 Spark编程模型(二)
查看>>
一线架构师实践指南:云时代下双活零切换的七大关键点
查看>>
ART世界探险(19) - 优化编译器的编译流程
查看>>
玩转Edas应用部署
查看>>
music-音符与常用记号
查看>>
sql操作命令
查看>>
zip 数据压缩
查看>>
Python爬虫学习系列教程
查看>>
【数据库优化专题】MySQL视图优化(二)
查看>>
【转载】每个程序员都应该学习使用Python或Ruby
查看>>
mongoose crud
查看>>
[Head First设计模式]山西面馆中的设计模式——装饰者模式
查看>>
PHP高级编程之守护进程,实现优雅重启
查看>>
PHP字符编码转换类3
查看>>
【2016阿里安全峰会】解读安全人才缺乏困境破解之法【附PDF下载】
查看>>
50条大牛C++编程开发学习建议
查看>>
rsync同步服务配置手记
查看>>
Android下创建一个sqlite数据库
查看>>