html网易云音乐图片轮播效果,Vue之网易云音乐PC版轮播图的实现

Github - program-learning-lists

最近在刷网易云音乐歌单时发现首页的轮播图很有意思,正好自己想尝试做一个PC版的网易云音乐,于是就是使用Vue去做这个demo,废话少说,我要出招了,接招吧

1d584ae523bea9b2cfb7f375167aee5c.gif

页面的DOM结构

:style="sliderStyle"

@mouseover="pause()"

@mouseout="play()">

:key="index"

:class="setClass(index)"

@click="onClick(index)" :style="setBGImg(item.src)">

:style="setActiveDot(index)"

@mouseover="currentIndex = index">

Slider-container的样式(Stylus)

.slider-container

width: 100%

height: 100%

text-align: center

padding: 10px 0

position: relative

这个子组件主要分为两块。

第一块、轮播图,其中它们的业务逻辑是

自动切换

左右icon切换轮播图

点击前后轮播图切换轮播图

鼠标滑动到轮播图停止轮播,离开后继续轮播

Slider-content的DOM结构

:key="index"

:class="setClass(index)"

@click="onClick(index)" :style="setBGImg(item.src)">

Slider-content的样式(Stylus)

.slider-content

position: relative

width: 100%

height: calc(100% - 20px)

left: 0%

top: 0%

margin: 0px

padding: 0px

background-size: inherit

.slider

position: absolute

margin: 0

padding: 0

top: 0

left: 50%

width: 65%

height: 100%

transition: 500ms all ease-in-out

background-color: #fff

background-repeat: no-repeat

background-position: center

background-size: inherit

transform: translate3d(-50%,0,-80px)

z-index: 1

&:before

position: absolute

content: ""

width: 100%

height: 100%

top: 0

left: 0

background-color: rgba(0, 0, 0, 0)

transition-delay: 100ms!important

transition: all 500ms

cursor: pointer

&.active

transform: translate3d(-50%, 0, 0)

z-index: 20

&.prev

transform: translate3d(-75%, 0, -100px)

z-index: 19

&.next

transform: translate3d(-25%, 0, -100px)

z-index: 18

i

width: 17.5%

display: none

position: absolute

top: 40%

font-size: 22px

color: rgba(255, 255, 255, 0.5)

text-shadow: 0 0 24px rgba(0, 0, 0, 0.3)

cursor: pointer

z-index: 21

&:first-child

left: 0

&:last-child

right: 0

&:hover

i

color: rgba(255, 255, 255, 0.8)

display: block

&.mask

.slider

&.prev, &.next

&:before

background-color: rgba(0, 0, 0, 0.50)

第二块、底部的dot, 其中它们的业务逻辑是

当前轮播图对应位置的dot高亮

鼠标移动到相应的dot上切换对应位置的轮播图

Dots的DOM结构

:style="setActiveDot(index)"

@mouseover="currentIndex = index">

Dots的样式(Stylus)

.dots

width: 100%

height: 20px

span

display: inline-block

width: 20px

height: 2px

margin: 1px 3px

cursor: pointer

上面是页面的DOM结构和表现的实现代码,接下来我们要讲的是连招的实现,小心啦,我要摸眼W + R3了。

上面我们讲到轮播图的业务逻辑,接下来,我们就讲讲如何实现的的吧

自动轮播

00306db4cc6dcaad63029093e1647886.gif

play () {

this.pause();

if (this.autoPlay) {

this.timer = setInterval(()=>{

this.next();

}, this.interval)

}

}

暂停轮播

54257036874841886a0781a46a9a2603.gif

pause () {

clearInterval(this.timer);

}

Icon切换轮播图

992949ec0c098cf60b75ccb3a8df94b5.gif

next () {

this.currentIndex = ++this.currentIndex % this.list.length;

},

prev () {

this.currentIndex = this.currentIndex === 0 ? this.list.length - 1 : this.currentIndex - 1;

},

前后轮播图的切换轮播图

c6a243f804afdc7fec65c54e2507064e.gif

onClick (i) {

if (i === this.currentIndex){

this.$emit('sliderClick', i);

} else {

let currentClickClassName = this.sliderDomList[i].className.split(' ')[1]

console.log(currentClickClassName)

if (currentClickClassName === 'next') {

this.next()

} else {

this.prev()

}

}

}

dots轮播图的切换轮播图

5f475f8dec67594cb66d6afdfb508330.gif

这里比较简单,只需要设置它的鼠标事件即可

@mouseover="currentIndex = index"

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/468054.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

深入理解mybatis原理, Mybatis初始化SqlSessionFactory机制详解(转)

文章转自http://blog.csdn.net/l454822901/article/details/51829785 对于任何框架而言,在使用前都要进行一系列的初始化,MyBatis也不例外。本章将通过以下几点详细介绍MyBatis的初始化过程。 1.MyBatis的初始化做了什么 2. MyBatis基于XML配置文件创建C…

我有个队友,叫悟空

昨晚,是我们篮球队年终聚会,好像也是第一次组织篮球队的聚会,之前就只知道在场上打球,场下就没有过这样的吃饭聚会。年终的时候,聚会特别多,该交流感情的交流感情,该年会抽奖的就年会抽奖&#…

C#基于LibUsbDotNet实现USB通信(一)

网上C#USB通信的资料比较少, 基本上都是基于LibUsbDotNet 和 CyUsb, 关于打印机设备的还有一个OPOS。 本篇文章基于LibUsbDotNet。 1. 下载并安装 LibUsbDotNet 安装文件。 2. 运行Filter Wizard, Install a device filter。 安装需要通信的usb设备。 3. 建一个简单…

一个大神的Android成长之路

这篇文章是我的一个朋友写的,总结了这些年的技术成长之路,我觉得对于很多技术人都有借鉴的作用,技术是相通的,不要整天想一口气吃成一个胖子,不积跬步无以至千里,既然选择了技术这条路,就不畏艰…

串口通讯你真的会了吗?不妨看看这些经验

平时使用串口打印出现乱码的绝大部分原因是串口波特率没对。那么我们怎么测量实际的波特率呢?在这之前,顺便一起回顾一下波特率的概念。什么是波特率、比特率? 比特率(Bitrate)表示每秒钟传输的二进制位数,单位为比特每秒(bit/s)。…

一些函数、变量命名法及代码规范

驼峰命名法 骆驼式命名法(Camel-Case)又称驼峰式命名法,也称小驼峰式命名法。骆驼式命名法就是当变量名或函数名是由一个或多个单词连结在一起时,第一个单词以小写字母开始;从第二个单词开始以后的每个单词的首字母都采…

linux 信号_[入门]谈一谈Linux中的信号

也许有一些同学有这样的疑问:kill -9 PID 中的 -9 到底是什么意思?Ctrl C 是为什么可以停止掉运行的程序?1. 什么是信号?在计算机科学中,信号是Unix、类Unix以及其他POSIX兼容的操作系统中进程间通讯的一种有限制的方…

终于讲透了,史上最详细的RS485串口通讯!

RS485接口组成的半双工网络,一般是两线制,多采用屏蔽双绞线传输,这种接线方式为总线式拓扑结构在同一总线上最多可以挂接32个结点。我们知道,最初数据是模拟信号输出简单过程量,后来仪表接口是RS232接口,这…

react 组件封装原则_我理解的React:React 到底是什么?

希望本文能帮助没接触过 React 的同学,对React有个大致的理解。最近要做一个“前端零基础的入门课程分享”,很多非前端同学可能只是知道 React 是个前端框架,整体对 React 的理解还是很模糊,借此机会,分享一下我对 Rea…

解引用NULL为什么会导致程序挂死?

来源:公众号【编程珠玑】作者:守望先生ID:shouwangxiansheng解引用NULL指针为什么会出错,导致程序挂死?或者说访问内存地址为0的位置为什么会视为非法?先了解NULL参考《NULL,0,\0有何区别?》。解…

关于主机的思维导图_送给孩子最好的思维导图课程

思维导图寒假班来了1关于思维导图思维导图是一种简单而有效的图形思维工具,主要元素包含图形、线条、关键字、颜色,配合下图,我们能理解思维导图利用了左脑和右脑的工作机理,能够充分调动大脑的分析推理和想象创新能力&#xff0c…

那年夏日我吃瓜

好吧,标题就是为了吸引读者进来增加阅读量的,作为一个公众号小编,我没有什么大量的墨水贡献给大家,但是就是想吹牛逼一下。我最近很懒,都有好几天没有更新新的文章了,然后大家也看到我自己写的东西没有什么…

未来计算机是否有意识或者人为的赋予意识,人工智能会有自我意识吗?

在西雅图的艾伦脑科学研究所,正在进行大规模的研究,以了解人脑中860亿个神经元是如何连接的。目的是产生所有连接的图:连接组。该研究所的科学家现在正在重建一立方毫米的老鼠大脑,这是有史以来最复杂的。绘制出大脑连接方式的映射…

别瞎找了,你要的C语言经典示例都在这~

大家周末好,这篇文章是从朋友的号那边看到的,确实不错,如果C语言还觉得没有胸有成熟的话,可以看看。里面的例子都很经典,有条件的同学实际操作一下。给大家找了一些C语言经典示例,github链接:ht…

广联达文件被锁怎么修复_事无巨细的绕过Apple id教程+修复蜂窝数据/电话

本次教程首发于Apple tech752大神,十分感谢他的nice job!通过这份教程你可以绕过Apple id激活锁,并且保留通话和移动数据和短信的功能,解决了由于基带锁导致绕过ID的机器不可以打电话的问题。写在前面:1.请勿用于捡到/…

计算机辅助翻译专业院校,2017年北大计算机辅助翻译考研经验分享

2017年北大计算机辅助翻译考研经验分享【摘要】笔者完美地将自身优势与兴趣相结合,最终成功折桂北大计算机辅助翻译。►择校(兴趣优势)其实我最开始考研的目标并不是北大的计算机作者hhhhhh1111次阅读2017-07-06【摘要】笔者完美地将自身优势与兴趣相结合&#xff0…

如何写出让同事无法维护的代码?

译文:http://coolshell.cn/articles/4758.html原文:http://mindprod.com/jgloss/unmain.html文章转自公众号 strongerHuang对,你没看错,本文就是教你怎么写出让同事无法维护的代码,因为只有这样,别人才不能…

调试,是一件有挑战的事情

如果你不是工程师,你应该享受不到加班调试的乐趣吧,我记得在大学的时候,我第一次调试I2C时序,当时用的芯片是24C02的RTC芯片,用51单片机模拟I2C时序,怎么整也整不出来,时序这个东西,…

make 命令_make考点总结(建议中、高考学生收藏)

考点一、“make宾语宾语补足语”结构1、这个结构表示“ 使…… 处于某种状态”“ 使……怎么样”。其中宾语的补足语,通常是表示情感的词(happy, sad)或者是表示状态的词(rich, strong, ill)。比如,Make your room clean.“使你的房间干净”,…

如何通俗易懂的解释PWM?

学过电力电子的小伙伴们都知道…交流电“整流”为直流电(a)…直流电“逆变”为交流电(b)…交流电“变压”为交流电(c)…直流电“斩波”为直流电(d)…“变压”(c&#xff…