angular下实现轮播图

angular下实现轮播图不需要像jq那样操作dom,本人将轮播图封装成了一个组件,实现的效果图如下

代码如下

1.html文件


  <ul [@carousel] = 'state'>

    <li class='imgP' [ngClass]="{'activeLi': img.state===true}" *ngFor='let img of images,let i =index;' (mouseleave)='start()' (touchstart)="getStartX($event)" (touchend)="getEndX(i)" (touchmove)="getMoveX($event)">

      <img [src]="url+img.name"  *ngIf='img.state'>

    </li>

  </ul>

  <div class='dot' fxLayout="row" fxLayoutAlign="center end" fxLayoutGap="15px">

    <div class='circle' [class.active]='img.state'  *ngFor='let img of images' (mouseenter)="clickDot(img.id)" (mouseleave)='blurDot()'>

    </div>

  </div>

</div>

#### 2.ts文件

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

import {trigger, style, transition, query, animate, group} from '@angular/animations';

@Component({

  selector: 'app-carousel',

  templateUrl: './carousel.component.html',

  styleUrls: ['./carousel.component.scss'],

  animations: [

    trigger('carousel', [

      transition(':increment', [

        group([

            query(':enter', [

                  style({transform: 'translateX(-100%)'}),

                  animate('1s')

              ]),

              query(':leave',[

                  animate('1s', style({transform: 'translateX(100%)'}))

              ])

          ])

        ]),

      transition(':decrement', [

        group([

          query(':enter', [

                style({transform:  'translateX(100%)'}),

                animate('1s')

            ]),

            query(':leave', [

                animate('1s', style({transform: 'translateX(-100%)'}))

            ])

        ])

      ]),

    ])

  ]

})

export class CarouselComponent implements OnInit, OnDestroy {

  url = '/assets/images/';        //图片文件路径

  state = 0;                                 

  timer: any;                              //定时器

  imgIndex = 2;

  startX: any;                             //起始触摸位置

  endX: any;                              //离开触摸位置

  startTime: number;              //其实触摸时间

  endTime: number;                //结束触摸时间

  screenWidth = document.documentElement.offsetWidth;

  images = [

    {id: 1, name: 'marketBg1.jpg', state: true},

    {id: 2, name: 'marketBg2.jpg', state: false},

    {id: 3, name: 'marketBg3.jpg', state: false},

    {id: 4, name: 'marketBg4.jpg', state: false},

  ];

  constructor() { }

//组件初始化后立即调用轮播方法fn()

 ngOnInit() {

    this. timer = setInterval(() => this.fn(), 5000);

  }

  ngOnDestroy() {

    // 停止轮播

    this.stop();

    //清空定时器

     clearInterval(this. timer);

  }

  fn() {

    this. imgIndex++;

    //轮播到最后一张图片时将图片索引置为零

    if (this.imgIndex> this.images.length - 1) {

        this.imgIndex = 0;

    }

 this.images.forEach(val => {

      val.state = false;

    });

    this.images[this.imgIndex].state = true;

  }

   //结束轮播

  stop() {

    clearInterval(this. timer);

  }

   //开始轮播

  start() {

    this. timer = setInterval(this.fn.bind(this), 5000);

  }

   //点击圆点切换轮播图,停止自动轮播

  clickDot(dotIndex) {

    this.imgIndex = dotIndex - 1;

    this.images.forEach(val => {

      val.state = false;

    });

    this.images[dotIndex - 1].state = true;

    this.stop();

  }

  blurDot() {

    this.start();

  }

    //获取初始滑动位置

  getStartX(e) {

    this.stop();

    this.startTime = Date.now();

    const touch = e.touches[0] || e.changedTouches[0];

    this.startX = touch.pageX;

  }

  // 获取滑动距离

  getMoveX(e) {

    const touch = e.touches[0] || e.changedTouches[0];

    this.endX = touch.pageX;

  }

  // 滑动结束位置

  getEndX(imgIndex) {

    const dx =  this.endX - this.startX;

    const dTime = Date.now() - this.startTime;

    if (Math.abs(dx) > this.screenWidth / 3 || (dTime < 300 && Math.abs(dx) > 30)) {

      this.images.forEach(val => {

        val.state = false;

      });

        // 右滑动

      if (dx > 0) {

        const leftDragIndex  = imgIndex === this.images.length - 1 ? 0 : imgIndex + 1;

        this.images[leftDragIndex].state = true;

      } else { 

        // 左滑动

        const rightDragIndex  = imgIndex === 0 ? this.images.length - 1 : imgIndex - 1;

        this.images[rightDragIndex].state = true;

      }

    }

    //确保清空旧的定时器

    this.stop();

    this.start();

  }

}

#### 3.css文件

div.container {

  position: relative;

  width: 100%;

  height: 100%;

}

  ul {

    position:relative;

    height: 100%;

    width: 100%;

    margin: 0;

    padding: 0;

  }

    li.activeLi {

      z-index: 5;

    }

    li.imgP{

      position: absolute;

      list-style: none;

      width: 100%;

      height: 100%;

      left: 0;

      right: 0;

    }

    img {

      border: none;

      height:  100%;

      width: 100%;

      border-radius: 0 0 16px 16px;

    }

 div.dot{

    position:absolute;

    display:flex;

    margin-top: 20px;

    justify-content:center;

    align-items:center;

    z-index: 6;

  }

   div .circle{

      float:left;

      background: #fff;

      width: 8px;

      height: 8px;

      border-radius: 50%;

    }

    div.active{

      width: 20px;

      height: 6px;

      border-radius: 2px;

      overflow: hidden;

      border: 1px solid #FF5F5F;

      background: #FF5F5F;

    }

水平有限,互相学习,如有不足,感谢指正
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 202,802评论 5 476
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,109评论 2 379
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 149,683评论 0 335
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,458评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,452评论 5 364
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,505评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,901评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,550评论 0 256
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,763评论 1 296
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,556评论 2 319
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,629评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,330评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,898评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,897评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,140评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,807评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,339评论 2 342