类似的效果如下图:

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. Linux学习记录(三)

    1.Linux的软件安装 1.1.jdk安装 注意:rpm与软件相关命令 相当于window下的软件助手 管理软件 步骤: 1)查看当前Linux系统是否已经安装java 输入 rpm -qa | g ...

  2. C#继承机制 访问与隐藏基类成员

    (1) 访问基类成员 通过base 关键字访问基类的成员:   调用基类上已被其他方法重写的方法.  指定创建派生类实例时应调用的基类构造函数.  基类访问只能在构造函数.实例方法或实例属性访问器中进 ...

  3. 操作系统(5)_内存管理_李善平ppt

    i386先通过段是管理,在通过页是管理

  4. CSS的垂直居中和水平居中总结

    内联元素居中方案 水平居中设置: 行内元素 设置 text-align:center: Flex布局 设置display:flex;justify-content:center;(灵活运用) 垂直居中 ...

  5. SummerVocation_Learning--java的自动打包与解包

    Auto Boxing: 自动将基础类型转换成对象(JDK1.5之后支持) Auto UnBoxing:自动将对象转换成基础类型 如 Map中的put方法,如果要传入键值对<a,1>,&l ...

  6. 可拖拽div

    在开发的时候需要一个可拖拽的prompt弹框.自己写了一个,大概思路为: 1.获取鼠标左键按下移动的起点坐标(x,y). 2.获取div的left和top属性. 3.得到鼠标坐标到左上角的距离(x-t ...

  7. java抓取12306火车余票信息

    最近在弄一个微信的公众帐号,涉及到火车票查询,之前用的网上找到的一个接口,但只能查到火车时刻表,12306又没有提供专门的查票的接口.今天突然想起自己直接去12306上查询,抓取查询返回的数据包,这样 ...

  8. centos 关闭AliYunDun

    执行命令: service aegis stop #停止服务 chkconfig --del aegis # 删除服务

  9. stm32-IIC读写EEPROM—时序说明

    I2C 通讯协议:(Inter-Integrated Circuit)是由Phiilps 公司开发的,由于它引脚少,硬件实现简单,可扩展性强,不需要USART.CAN  等通讯协议的外部收发设备,现在 ...

  10. 三次样条插值matlab实现

    三次样条插值matlab实现 %三次样条差值-matlab通用程序 - zhangxiaolu2015的专栏 - CSDN博客 https://blog.csdn.net/zhangxiaolu201 ...