我们都知道Ionic3为我们提供了一套丰富易用的UI组件库,然而凡事是都有不完美之处,今天我们来看一下ionic3 slides组件在实现轮播功能时候的小问题。

先开UI小姐姐给到的3张美美哒效果图

接下来是home.html下的组件使用

<div class="slide-wrap">

<ion-slides pager loop="true" autoplay="3000" >

<ion-slide>

<h1><img src="assets/imgs/banner.png"></h1>

</ion-slide>

<ion-slide>

<h1><img src="assets/imgs/banner2.png"></h1>

</ion-slide>

<ion-slide>

<h1><img src="assets/imgs/banner3.png"></h1>

</ion-slide>

</ion-slides>

  

我们看标签ion-slides上的属性配置 pager loop="true" autoplay="3000"

解析一下

其中标签ion-slides上是属性 page表示轮播图开启显示当前页码,loop="true"表示开启循环播放 autoplay="3000"表示每个3秒钟自动播放一次。

根据我们的需求,按照文档配置属性后,下面就是见证奇迹的时候了。。。轮播图上的小点出现了,也能循环轮播了,并且每个3秒后还会自动轮播--  perfect

然而正当你兴高采烈、自信满满的拿起手机准备向小伙伴们炫耀或者向产品经理邀功的路上一不小心用你那高贵的小金手指滑动了轮播图时。。整个世界突然安静了下来,

What!!怎么不动了?轮播怎么卡翔了?手机突然坏了?不会是出bug了吧?。。不相信的你,于是又借了后端小哥哥的手机看一下。。发现还是一样的问题:可以3秒钟之后自动轮播,也可以循环播放。。

but,当你用手指触摸一下轮播,让它播到下一页后。于是你便在那里小心翼翼的患得患失的默默的数着;’1,2,3,4,5’,这么还不自动播放?再次刷新,重复之前的操作,12345,怎么还是不播放呢。

于是答案肤之欲出:’啊!!出bug了!’。

‘趁着没人发现,赶紧偷偷的改掉’。

于是乎历经千辛万苦的查阅文档,各大论坛求助,终于被你找到了破解之法

首先第一步:想要修改轮播图的问题,你得先找到轮播元素

其次第二步:在合适的时机做针对的事

接下来重点来了,请看代码

在home.ts文件下

1.导入ViewChild ,Slides 并通过@ViewChild匹配到组件 Slides元素

import { Component,ViewChild } from '@angular/core';

import { Slides } from 'ionic-angular';

@ViewChild(Slides) slides: Slides;

2.在ionViewDidEnte生命周期里设置该参数 autoplayDisableOnInteraction 为false

ionViewDidEnter() {

this.slides.autoplayDisableOnInteraction = false;

}

完整home.ts代码

import { Component,ViewChild } from '@angular/core';
import { NavController,Slides } from 'ionic-angular';
import {UserBaseInfoPage} from '../user-base-info/user-base-info'
import {LoginPage} from '../login/login'
import {RestProvider} from '../../providers/rest/rest'
import { Storage } from '@ionic/storage'
// @IonicPage()
@Component({
selector: 'page-home',
templateUrl: 'home.html'
})
export class HomePage {
@ViewChild(Slides) slides: Slides;
constructor(public navCtrl: NavController,
public rest: RestProvider,
public storage: Storage) { }
ionViewWillEnter() {
this.checkToken()
}
ionViewDidEnter() {
//修复轮播手动滑动后不能自动轮播问题
this.slides.autoplayDisableOnInteraction = false;
console.log(this.slides)
}
checkToken () {
var api='Main/MainQuest?needload'; //验证token接口
this.storage.get('token').then((val) => {
var params = {
token: val
}
if (!val) {
this.navCtrl.push(LoginPage);
return
}
this.rest.doPost(api,params, (data)=> { if(!data.issuccess) {
this.navCtrl.setRoot(LoginPage);
}
})
})
} gotoUserInfo() {
this.navCtrl.push(UserBaseInfoPage);
}
}

再次调试一下,,完美。。Over

观看线上效果可以微信关注二维码,通过菜单栏ETC业务进入首页即可观看

ionic3 slides轮播图手动滑动后无法自动播放问题的更多相关文章

  1. Vue中swiper手动滑动后不能自动播放的解决方法

    用户操作swiper之后,是否禁止autoplay.默认为true:停止.如果设置为false,用户操作swiper之后自动切换不会停止,每次都会重新启动autoplay.操作包括触碰,拖动,点击pa ...

  2. photoSlider-html5原生js移动开发轮播图-相册滑动插件

    简单的移动端图片滑动切换浏览插件 分别引用css文件和js文件 如: <link rel="stylesheet" type="text/css" hre ...

  3. Ionic4.x 中的 UI 组件(UI Components) Slides 轮播图组件、Searchbar 组件、 Segment 组件

    Slides 轮播图组件 Ionic4.x 中的轮播图组件是基于 swiper 插件,所以配置 slides 的属性需要在 swiper 的 api 中 找 Swiper Api:http://ida ...

  4. Android侧滑菜单和轮播图之滑动冲突

    接手一个项目,有一个问题需要修改:轮播图不能手动滑动,手动滑动轮播图只会触发侧滑菜单. 猜测:viewpager控件(轮播图)的触摸事件被SlidingMenu控件(侧滑菜单,非第三方项目,乃是上个开 ...

  5. 用 JS 写 (轮播图 / 选项卡 / 滑动门)

    页面中经常会用到各式各样的轮播图,今天贺贺为大家介绍一种常用的方法,对于JS我们需要举一反三,一种方法可以对多个轮播样式进行渲染. <head> <meta charset=&quo ...

  6. Ionic slides 轮播图

    1. 创建界面 <ion-content> <ion-slides pager class="myslides"> <ion-slide> &l ...

  7. swiper框架,实现轮播图等滑动效果

    http://www.swiper.com.cn/ 做个记录而已,这个没什么好说的,对于需要手机端开发实现触摸等方式可以看看.

  8. 探索javascript----我对渐变轮播图的理解

    对于一个没有编程基础的人来说,我时常希望能有人告诉我,当我们看到一个效果的时候,该怎样有条理地分析出它的行为,而我自己有必要加强这方面的 自省,对于一个轮播图我是这样看的,自动播放必然带有一个定时器, ...

  9. 轮播图--js课程

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

随机推荐

  1. anaconda3安装cv2模块(python3.6)

  2. 看完此文还不懂NB-IoT,你就过来掐死我吧...【转】

    转自:https://www.cnblogs.com/pangguoming/p/9755916.html 看完此文还不懂NB-IoT,你就过来掐死我吧....... 1 1G-2G-3G-4G-5G ...

  3. Beta冲刺(4/7)

    目录 摘要 团队部分 个人部分 摘要 队名:小白吃 组长博客:hjj 作业博客:beta冲刺(4/7) 团队部分 后敬甲(组长) 过去两天完成了哪些任务 整理博客 ppt模板 接下来的计划 做好机动. ...

  4. 记录一次Python下Tensorflow安装过程,1.7带GPU加速版本

    最近由于论文需要,急需搭建Tensorflow环境,16年底当时Tensorflow版本号还没有过1,我曾按照手册搭建过CPU版本.目前,1.7算是比较新的版本了(也可以从源码编译1.8版本的Tens ...

  5. OpenCV3编程入门读书笔记4-形态学滤波

    一.腐蚀和膨胀 1.腐蚀和膨胀的主要功能 (1)消除噪声 (2)分割出独立的图像元素,在图像中连接相邻的元素 (3)寻找图像中的极大值或者极小值区域 (4)求出图像的梯度 2.膨胀(dilate) 膨 ...

  6. shim和polyfill

    shim是将新的api引入旧的环境 polyfill是一段代码或插件 https://www.aliyun.com/jiaocheng/773254.html 理解得不够透彻...

  7. Java设计模式迭代器

    定义:提供一种方法,顺序访问一个集合对象中的各个元素,而又不暴露该对象的内部表示. 类型:行为型 适用场景: 访问一个集合对象的内容而无需暴露它的内部表示 为遍历不同的集合结构提供一个统一的接口 优点 ...

  8. 前端技术之--HTML

    1.一套规则,浏览器认识的规则. 2.开发者: 学习Html规则 开发后台程序: - 写Html文件(充当模板的作用) ****** - 数据库获取数据,然后替换到html文件的指定位置(Web框架) ...

  9. Tomcat Getshell

    安装环境 账号密码路径:Tomcat6.0/conf/tomcat-users.xml 弱口令扫描工具 后台默认登陆地址:html://xx.xx.xx.xx/manager/html 后台war f ...

  10. css margin使用技巧

    margin使用技巧: (1)设置元素水平居中:margin:x auto; (2)margin负值让元素位移及边框合并 水平居中:auto 代码: <!DOCTYPE html> < ...