网站首页 > 博客文章 正文
今天给大家分享3个超丝滑Vue卡片左右、上下滑动层叠组件VueCardSlide。
1、vue-tantan-stack
一款基于 vue.js 制作的仿探探效果滑动组件。支持左右拖动或点击按钮切换效果。
功能分析
堆叠滑动的功能很简单,用一张图概括就是
堆叠效果
堆叠图片效果在网上有大量的实例,实现的方法大同小异,主要通过在父层设定 perspective 及 perspective-origin,来实现子层的透视,子层设定好 translate3d Z轴数值即可模拟出堆叠效果。
// 图片堆叠dom
<!--opacity: 0 隐藏我们不想看到的stack-item层级-->
<!--z-index: -1 调整stack-item层级"-->
<ul class="stack">
<li class="stack-item" style="transform: translate3d(0px, 0px, 0px);opacity: 1;z-index: 10;"><img src="1.png" alt="01"></li>
<li class="stack-item" style="transform: translate3d(0px, 0px, -60px);opacity: 1;z-index: 1"><img src="2.png" alt="02"></li>
<li class="stack-item" style="transform: translate3d(0px, 0px, -120px);opacity: 1;z-index: 1"><img src="3.png" alt="03"></li>
<li class="stack-item" style="transform: translate3d(0px, 0px, -180px);opacity: 0;z-index: -1"><img src="4.png" alt="04"></li>
<li class="stack-item" style="transform: translate3d(0px, 0px, -180px);opacity: 0;z-index: -1"><img src="5.png" alt="05"></li>
</ul>
<style>
.stack {
width: 100%;
height: 100%;
position: relative;
perspective: 1000px; //子元素视距
perspective-origin: 50% 150%; //子元素透视位置
-webkit-perspective: 1000px;
-webkit-perspective-origin: 50% 150%;
margin: 0;
padding: 0;
}
.stack-item{
background: #fff;
height: 100%;
width: 100%;
border-radius: 4px;
text-align: center;
overflow: hidden;
}
.stack-item img {
width: 100%;
display: block;
pointer-events: none;
}
</style>
上面只是一组静态代码,我们希望得到的是vue组件,具体实现方法大家可以去参看源码。
安装
$ npm i vue-tantan-stack -S
使用组件
<template>
<div class="mid-center">
<div class="stack-wrapper">
<stack ref="stack" :pages="someList" :stackinit="stackinit"></stack>
</div>
<div class="controls">
<button @click="prev" class="button"><i class="prev"></i><span class="text-hidden">prev</span></button>
<button @click="next" class="button"><i class="next"></i><span class="text-hidden">next</span></button>
</div>
</div>
</template>
<script>
import stack from '../components/stack'
export default {
el: '#stack',
data () {
return {
someList: [],
stackinit: {
visible: 3
}
}
},
mounted () {
let that = this
setTimeout(function () {
that.someList = [
{ html: '<img src="src/img/1.png" alt="01">' },
{ html: '<img src="src/img/2.png" alt="02">' },
{ html: '<img src="src/img/3.png" alt="03">' },
{ html: '<img src="src/img/4.png" alt="04">' },
{ html: '<img src="src/img/5.png" alt="05">' },
{ html: '<img src="src/img/6.png" alt="06">' },
{ html: '<img src="src/img/7.png" alt="07">' }
]
}, 2000)
},
components: {
stack
},
methods: {
prev () {
this.$refs.stack.$emit('prev')
},
next () {
this.$refs.stack.$emit('next')
}
}
}
</script>
最后附上demo及项目地址
# demo地址
https://warpcgd.github.io/vue-tantan-stack/
# 仓库地址
https://github.com/warpcgd/vue-tantan-stack
2、vue-card-slide
基于 vue2.x 构建的卡片拖动切换组件。和第一个有些类似,不过实现方式不一样,大家可以去看看。
项目结构
安装
$ npm i vue-card-slide -S
使用组件
<template>
<div class="card-wrapper">
<vue-card-slide @success='sucEvent' @error='errEvent'></vue-card-slide>
</div>
</template>
<script>
import cardSlide from 'vue-card-slide'
export default {
data () {
return {}
},
components: {
cardSlide
},
methods: {
sucEvent(value) {
console.log(value)
},
errEvent(value) {
console.log(value)
}
}
}
</script>
# 项目github地址
https://github.com/Carrie999/vue-card-slide
3、vue-slide-card
vue层叠卡片滑动切换、卡牌动态滑动切换效果。
大家可以根据需要自行定制一些酷炫的效果。
# demo地址
http://www.yunfengzhijia.cn/git-demo/vue-slide-card/#/
# 仓库地址
https://github.com/Kevin-269581661/vue-slide-card
ok,就介绍到这里。感兴趣的小伙伴们可以去看下,欢迎交流分享。
猜你喜欢
- 2024-11-25 又一个布局利器,CSS 伪类 :placeholder-shown
- 2024-11-25 值得收藏的CSS小技巧
- 2024-11-25 尤娜v1.2.2内置函数用法-Part II(分页函数)
- 2024-11-25 总结7个工作中常用的css3案例,带你了解冷门却实用的特性
- 2024-11-25 带你手写一个轮播图之HTML结构和CSS布局设计
- 2024-11-25 稍微整理了几个经常在H5移动端开发遇到的东西
- 2024-11-25 七爪源码:如何使用 vanilla JS & CSS 创建滚动到顶部按钮
- 2024-11-25 吃透 Vue 项目开发实践|16个方面深入前端工程化开发技巧【上】
- 2024-11-25 揭秘前端无刷新提交数据的黑科技 - React Server Actions深度解析
- 2024-11-25 还在用 JS 做节流吗?CSS 也可以防止按钮重复点击
你 发表评论:
欢迎- 最近发表
- 标签列表
-
- powershellfor (55)
- messagesource (56)
- aspose.pdf破解版 (56)
- promise.race (63)
- 2019cad序列号和密钥激活码 (62)
- window.performance (66)
- qt删除文件夹 (72)
- mysqlcaching_sha2_password (64)
- ubuntu升级gcc (58)
- nacos启动失败 (64)
- ssh-add (70)
- jwt漏洞 (58)
- macos14下载 (58)
- yarnnode (62)
- abstractqueuedsynchronizer (64)
- source~/.bashrc没有那个文件或目录 (65)
- springboot整合activiti工作流 (70)
- jmeter插件下载 (61)
- 抓包分析 (60)
- idea创建mavenweb项目 (65)
- vue回到顶部 (57)
- qcombobox样式表 (68)
- vue数组concat (56)
- tomcatundertow (58)
- pastemac (61)
本文暂时没有评论,来添加一个吧(●'◡'●)