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

简介: 版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/inforstack/article/details/77806847 自定义组件我开始构建一个简单的实现,最后一个自定义组件如下所示:自动获取标题高度,然后当标题滚动时,可扩展标题缩减开始被切断的任何元素将会消失(并退回到再次出现空间的位置)。
版权声明:本文为博主原创文章,未经博主允许不得转载。 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
<ng-content></ng-content>
  • scrollContent是我们在收听滚动事件的区域,以确定标题何时展开和缩小。
  • OnInit组件初始化的时候监听滚动事件。
  • 我们循环遍历组件所有子项,并检查元素的底部是否已被标题遮住。通过结合offsetTop与clientHeight每个元素的,我们能够制定出其中元件的底部实际上是相对于头部。
  • 通过设置isHidden属性跟踪当前元件是否显示。出于性能原因,我们希望尽可能避免DOM更新。
  • 通过domWrite是对dom的高效修改。
  • 设置overflow属性在此处非常重要,否则组件不可见时,标题中的内容将会溢出到内容区域中。

将组件添加到模板

<ion-header no-border>
    <super-header [scrollContent]="content">
        <ion-item>
            <ion-label>
                <ion-icon name="search"></ion-icon>
            </ion-label>
            <ion-input type="text"></ion-input>
        </ion-item>
    </super-header>
    <ion-navbar>
        <ion-title>Home</ion-title>
    </ion-navbar>
</ion-header>

<ion-content fullscreen #content>
    <ion-list>
        <ion-item *ngFor="let item of items">
            {{item}}
        </ion-item>
    </ion-list>
</ion-content>

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

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

源码分享地址



相关文章
|
Android开发
ionic3项目实战教程 - 第13讲 ionic3社交分享(QQ分享和微信分享)
ionic3项目实战教程 - 第13讲 ionic3社交分享(QQ分享和微信分享) 图片发自简书App 这一讲主要包含以下几个部分: 1.在微信开放平台创建应用获得wechatappid; 2.
1558 0
|
Android开发 iOS开发
ionic3项目实战教程 - 第12讲 ionic3制作icon和splash
这一讲主要包含以下几个部分: 1.设计icon; 2.设计splash; 3.生成各个平台各个尺寸的icon和splash; 1.设计icon 来,打开你的PS,新建-文件,像素为1024*1024,背景透明,确定; .
1313 0
|
Web App开发
ionic3项目实战教程 - 第11讲 ionic3个人中心界面设计
ionic3项目实战教程 - 第11讲 ionic3个人中心界面设计 这一讲主要包含一下几个部分: 1.个人中心ts具体代码展示; 2.个人中心html具体代码展示; 3.
1502 0
ionic3项目实战教程 - 第10讲 ionic3分类菜单设计(类似外卖)
注意,干货来了,相比前面几讲这一讲就要难以消化多了,请做好心理准备。 因为在这之前,经常看到有群友在求这种分类菜单的组建,今天我就为大家再造一个轮子 [微笑脸]。
1236 0
|
Web App开发
ionic3项目实战教程 - 第8讲 ionic3商品详情页的实现
这一讲主要包含以下几个部分: 1.创建商品详情页 2.获取商品详情页的数据 3.展示商品详情页的数据 1.创建商品详情页 执行 ionic g page product-details 8-1.
1184 0
|
Web App开发
ionic3项目实战教程 - 第9讲 ionic3应用内主题浏览器ThemeableBrowser的使用
这一讲主要实现商品的"抢购"功能 1.安装ThemeableBrowser插件; 2.使用ThemeableBrowser插件; 1.安装插件 分别执行以下命令: ionic cordova plugin add cordova-plugin-t...
1608 0
ionic3项目实战教程 - 第7讲 ionic3商品列表页的实现
这一讲主要包含以下几个部分: 1.创建商品列表页 2.根据分类获取商品列表 2.展示商品列表 1.创建商品列表页 执行 ionic g page product-list 7-1.
976 0
ionic3项目实战教程 - 第5讲 ionic3商城首页透明导航栏设计
这一讲主要包含以下几个部分 1.配置APP主色调; 2.设置ion-content组建的fullscreen属性; 3.设计透明导航栏 配置APP主色调; 找到src/theme/variables.
1471 0
|
Go
ionic3项目实战教程 - 第4讲 ionic3商城首页设计(幻灯片+图标分类)
商城首页主要包含以下几个部分 1.使用ion-slide实现首页幻灯片; 2.使用ion-grid实现商品分类; 3.使用ion-list实现商品列表; 说一下实现思路 1.先获取网络请求的数据,查看数据结构; 2.根据数据结构来判断需要展示的数据,编写html; 3.调整界面样式,编写scss; 准备工作 开始之前请到阿里开源图标库准备首页需要的小图标,不想自己找的同学,在文章最后的交流群的群文件里有导出好的资源小图标,下载后直接放到项目的src/assets/icon/目录中即可。
1310 0