类似的效果如下图:

1. 生成一个component

  1. ionic g component MySlide

2. 在my-slide.html中添加代码:

  1. <ion-slides class="slide-title" [options]="mySlideOptions">
  2. <ion-slide *ngFor="let slide of slides; let i = index;">
  3. <div (click)="onClick(i)">
  4. <span class="slide-title-unit" [ngClass]="{'slide-title-active': selectedIndex == i}">{{slide}}</span>
  5. </div>
  6. </ion-slide>
  7. </ion-slides>

其中slides是一个数组,存放类型字符串,如上图显示的"推荐", "环球"等

3. 在my-slide.ts中添加代码:

  1. import {Component, Input, Output, EventEmitter} from '@angular/core';
  2. @Component({
  3. selector: 'my-slide',
  4. templateUrl: 'build/components/my-slide/my-slide.html'
  5. })
  6. export class MySlide {
  7. @Input("slides") slides: string[] = [];
  8. @Input("pageNumber") pageNumber: number = 5;
  9. @Output("slideClick") slideClick = new EventEmitter<number>();
  10. mySlideOptions;
  11. selectedIndex: number = 0;
  12. constructor() {
  13. }
  14. ngOnInit() {
  15. this.mySlideOptions = {
  16. loop: false,
  17. autoplay: false,
  18. initialSlide: 0,
  19. pager: false,
  20. slidesPerView: this.pageNumber,
  21. paginationHide: true,
  22. paginationClickable: true
  23. };
  24. }
  25. onClick(index) {
  26. this.selectedIndex = index;
  27. this.slideClick.emit(index);
  28. }
  29. }

Input参数slides,my-slide的属性传入,显示类型的字符串数组。

Input参数pageNumber,my-slide的属性传入,表示当前屏幕可以显示的类型数目,默认为5。

Output参数slideClick,当点击某个类型时,将点击的index返回给使用者。

4. my-slide.scss

  1. $slide-height-small: 40px;
  2. $slide-height-large: 50px;
  3. .slide-title {
  4. width: 100%;
  5. height: $slide-height-small;
  6. color: #666666;
  7. padding: 0;
  8. }
  9. .slide-title-unit {
  10. padding-bottom: 8px;
  11. font-size: 14px;
  12. height: $slide-height-small;
  13. line-height: $slide-height-small;
  14. }
  15. .slide-title-active {
  16. color: map_get($colors, primary);
  17. border-bottom: 3px solid map_get($colors, primary);
  18. }

其中slide-title-active表示选中时改变类型文字颜色以及下方显示横线。

5. 使用方法:

  1. <my-slide (slideClick)="onSlideClick($event)" [slides]="pageSlides" [pageNumber]="7"></my-slide>

最后,不要忘记在@Component中添加directives: [MySlide]

ionic2 使用slides制作滑动效果的类型选择栏的更多相关文章

  1. Android 滑动效果入门篇(二)—— Gallery

    Gallery 是Android官方提供的一个View容器类,继承于AbsSpinner类,用于实现页面滑动效果. 从上面的继承关系可以看出,AbsSpinner类继承自AdapterView,因此我 ...

  2. 使用jQuery的animate方法制作滑动菜单

    周末看Ziv小威的博客<制作滑动条菜单,如何延时处理滑动效果,避免动画卡顿>,参见地址:http://www.cnblogs.com/zivxiaowei/p/3462964.html.是 ...

  3. Android Scroll分析——滑动效果产生

    相对于在Android2.x版本上出现的长按.点击事件的效果,不得不说,滑动操作具有更好的用户体验.因此,从Android 4.X版本开始,出现了更多滑动操作的效果.越来越多第三方应用模仿这样的效果, ...

  4. Unity3d NGUI的使用(九)(UIScrollView制作滑动列表)

    UIScrollView制作滑动列表,可横向,竖直展示一些列表在固定可视范围内 UIScrollVIew只是一个可滑动的UI组件 如果需要制作复杂的可视区域UI需要配合使用UIPanel与UIGrid ...

  5. Android实现左右滑动效果

    本示例演示在Android中实现图片左右滑动效果.   关于滑动效果,在Android中用得比较多,本示例实现的滑动效果是使用ViewFlipper来实现的,当然也可以使用其它的View来实现.接下来 ...

  6. Android 实现左右滑动效果ViewFlipper终结【转】

    本示例演示在Android中实现图片左右滑动效果.   关于滑动效果,在Android中用得比较多,本示例实现的滑动效果是使用ViewFlipper来实现的,当然也可以使用其它的View来实现.接下来 ...

  7. 利用CSS制作图形效果

    前言 关于如何使用CSS来制作图形,比如说圆形,半圆形,三角形等的相关教程还是挺多的,今天我主要想解释一下里面一些demo的实现原理,话不多说,开始吧   以下所有内容只使用一个HTML元素.任何类型 ...

  8. a 锚点跳转滑动效果

    点击a链接时,跳转到相应id的位置处,有一个滑动效果. <a href="#my">我是跳转到div</a><div id="my" ...

  9. jquery左右滑动效果的实现

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...

随机推荐

  1. python_38_try-except异常处理语句及raise的使用

    # i=10 # print(30/(i-10)) # #程序将会出现以下报错信息 # # Traceback (most recent call last): # # File "C:/U ...

  2. python_15_os

    import os #1. os.system('dir') #2 cmd_res=os.system('dir')#执行命令不保存结果 print("-------",cmd_r ...

  3. 04构建之法读书笔记——IT行业的创新

    IT行业的创新: 1.创新的迷思: 灵光一闪现,伟大的创新就紧随其后:大家都喜欢创新:好的想法会赢:创新者都是一马当先:要成为领域的专家,才能创新:技术的创新是关键:成功的团队更能创新 2.创新的时机 ...

  4. Python入门第一课——Python的起源、发展与前景!

    我们在做任何一件事情之前,我们都会通过各种渠道去搜集事情的信息,了解事情的来龙去脉,学习一门编程语言也是如此,只有知根知底,我们才能有明确的方向和目标,以及底气去完成这件事情,今天我带大家来看看Pyt ...

  5. POJ 3414 BFS 输出过程

    Pots Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 17456   Accepted: 7407   Special J ...

  6. The Moving Points - HDU - 4717 (模拟退火)

    题意 二维空间中有\(n\)个运动的点,每个点有一个初始坐标和速度向量.求出一个时间\(T\),使得此时任意两点之间的最大距离最小.输出\(T\)和最大距离. 题解 模拟退火. 这个题告诉了我,初始步 ...

  7. Http状态码(了解)

    一些常见的http状态码 200 - OK,服务器成功返回网页     - Standard response for successful HTTP requests. 301 - Moved Pe ...

  8. Kali 远程登陆SSH

    一.配置SSH 编辑/etc/ssh/sshd_config 将#PasswordAuthentication no的注释去掉,将NO修改为YES //可以用密码登陆 将PermitRootLogin ...

  9. 9 RESTful API

    1  RESTful API 2 post创建一个视频 put帖子加精,delete删除 3 自定义状态码 4 5 6 7 8

  10. P1880 石子合并

    P1880 石子合并 题目描述 在一个园形操场的四周摆放N堆石子,现要将石子有次序地合并成一堆.规定每次只能选相邻的2堆合并成新的一堆,并将新的一堆的石子数,记为该次合并的得分. 试设计出1个算法,计 ...