使用vue.js封装一个包含图片的跑马灯组件
初衷:
学习完Vuejs后,来准备练习仿写一下老东家的门户页面,主要是为了熟悉一下常用插件的使用,比如video.js,wow.js,swiper等等;而其中涉及到一个包含图片跑马灯组件,大概长这样(从左到右进行轮播 ps:太懒,没有截动图):
历程:
像我这样的小白,立马想到的肯定不是自己写了;于是百度查阅,看有没有现成的插件之类,搜索到了vue-marquee-tips,但是查看api,自己试用了一下,发现好像只支持纯文本,无法满足需求;
查询插件无果,又想着看一下有没有人已经写好了类似的组件,自己可以直接来用的(搜索和研究api就花费了30多分钟的时间,看来我真的很懒……),查询到一个无缝衔接的文字跑马灯,主要是用定时器对字符串进行切割和重新拼接来实现的,虽然代码实现相对简单,但对我这样的小白来说,个人觉得思路是挺不错的,这里附上链接:https://www.cnblogs.com/zhahuhu/p/11592400.html,但是该组件还是只能用于文字,无法满足需求;
终于,我放弃了找现成插件的想法(或许是百度用的不好吧……),准备自己封装一个跑马灯组件;
实现思路:
之前学习js的时候,使用定时器做过一个轮播图组件,考虑到跑马灯应该与之类似,只是定时器设置时间较短而已
首先使用一个外层div来包裹住展示区域div,外层div设置overflow:hidden,子绝父相进行定位,再定时改变子div的left,考虑到如果不设置条件判断,left会一直改变,所以要在left达到某个值时,将left设置回去,这样就可以实现一直轮播的效果,具体代码如下:
<template>
<div class="marquee">
<div class="marquee-content" @mouseover="clearTimer" @mouseout='startTimer'>
<div class="img-item" v-for="(item,index) in imglists" :key="index">
<img :src="item" alt="">
<span>视频点播</span>
</div>
</div>
</div>
</template> <script>
export default {
name: "Marquee",
components: {
},
data() {
return {
imglists: [],
timer: ''
};
},
created() {
for (var i = 1; i < 18; i++) {
this.imglists.push('http://www.360tianma.com/application/cms/static/images/component'+i+'.png')
}
this.imglists.push('http://www.360tianma.com/application/cms/static/images/component1.png')
// console.log(this.imglists)
},
mounted() {
this.startTimer();
},
methods: {
clearTimer() {
clearInterval(this.timer)
},
startTimer() {
var content = document.querySelector('.marquee-content');
this.timer = setInterval(() => {
var oldleftstr = getComputedStyle(content,null).left
var oldleft = parseInt(oldleftstr);
content.style.left = oldleft-1 + 'px'
if (oldleft <= -2925) {
content.style.left = 0
}
}, 10);
}
} };
</script> <style scoped>
.marquee {
width: 1140px;
height: 80px;
margin: 0 auto;
position: relative;
overflow: hidden;
margin-top: 100px;
padding: 15px;
}
.marquee-content {
width: 4050px;
position: absolute;
left: 0;
} .img-item {
width: 225px;
height: 80px;
line-height: 80px;
float: left;
text-align: center;
}
img {
width: 50px;
height: 50px;
}
</style>
注:因为是仿写,主要练习功能实现,所以上述代码中的图片都用for循环来添加成一样的了
个人总结:
上述代码虽然简单,而且也存在不少缺陷,但是也为今后解决类似的问题提供一种思路;对于我这样的小白也算是多一次练习和提升;以后遇到类似的组件,可能会多想到自己来封装,而非找其他插件;
该仿写页面已完成,github:https://github.com/Xiaohuimao/Vue-tianma.git,感兴趣的同学可自行查阅(该项目文件组织有点惨不忍睹,还望不要吐槽)
使用vue.js封装一个包含图片的跑马灯组件的更多相关文章
- vue.js 作一个用户表添加页面----初级
使用vue.js 制作一个用户表添加页面,实际上是把原来需要使用js写的部分,改写成vue.js的格式 首先,想象一下,先做思考,我们要添加用户表,设涉及到哪些数据,一个是用户id,一个是用户名,一个 ...
- ionic js 滑动框ion-slide-box 滑动框是一个包含多页容器的组件,每页滑动或拖动切换
ionic 滑动框 ion-slide-box 滑动框是一个包含多页容器的组件,每页滑动或拖动切换: 效果图如下: 用法 <ion-slide-box on-slide-changed=&quo ...
- 使用 JS 实现图片左右跑马灯
Ø 前言 之前写了一篇使用 JS 实现文字上下跑马灯,现在乘热打铁在把图片左右跑马灯一起贴出来,不多说直接看代码. 1. 首先定义 css 样式 <style type="tex ...
- vue中封装一个全局的弹窗js
/** * Created by yx on 2017/12/21. */ export default { /** * 带按钮的弹框 * <!--自定义提示标题,内容,单个按钮事件--> ...
- 用Vue.js开发一个电影App的前端界面
我们要构建一个什么样的App? 我们大多数人使用在线流媒体服务(如Netflix)观看我们最喜欢的电影或者节目.这篇文章将重点介绍如何通过使用vue.js 2 建立一个类似风格的电影流媒体WEB交互界 ...
- 结合Vue.js的前端压缩图片方案
这是一个很简单的方案.嗯,是真的. 为什么要这么做? 在移动Web蓬勃发展的今天,有太多太多的应用需要让用户在移动Web上传图片文件了,正因如此,我们有些困难必须去攻克: 低网速下上传进度缓慢,用户体 ...
- Vue.js实现一个SPA登录页面的过程
技术栈 vue.js 主框架 vuex 状态管理 vue-router 路由管理 一般过程 在一般的登录过程中,一种前端方案是: 检查状态:进入页面时或者路由变化时检查是否有登录状态(保存在cooki ...
- 用Vue.js搭建一个小说阅读网站
目录 1.简介 2.如何使用vue.js 3.部署api服务器 4.vue.js路由配置 5.实现页面加载数据 6.测试vue项目 7.在正式环境部署 8.Vue前端代码下载 1.简介 这是一个使用v ...
- Vue.js写一个SPA登录页面的过程
技术栈 vue.js 主框架 vuex 状态管理 vue-router 路由管理 一般过程 在一般的登录过程中,一种前端方案是: 检查状态:进入页面时或者路由变化时检查是否有登录状态(保存在cooki ...
随机推荐
- 如何实现浏览器的Console功能
离 JS-Encoder 的最初版本发布已经过了大半年的时间,这段时间除了偶尔修复一下 BUG 外,主要还是忙于学业.最近一段时间不太平,开学时间也大大延迟,加上自己本身对自己的在线编译器不是很满意, ...
- Unix 网络编程卷一源码编译踩坑记录 ubtutu 19.10
在阅读unpv1时运行源代码的环境配置,这里简单记录一下 源代码里的README 写得挺详细的,但是在Linux 系统的下还没没办法直接编译通过的, 这里我使用的是ubuntu 19.10(在腾讯云1 ...
- 第 k 小的数
一.寻找两个有序数组的中位数 1.1 问题描述 给定两个大小为 m 和 n 的不同时为空的有序数组 nums1 和 nums2.找出这两个有序数组的中位数,并且要求算法的时间复杂度为 O(log(m ...
- vue实现选项卡切换--不用ui库
vue的ui库中基本都有选项卡切换的组件,但是在项目开发过程中却不一定能很好的为我们所用,因为里面的样式和 一些状态并不能很好的根据我们的项目需求进行定制.最近项目中使用的是vant-ui中的标签页, ...
- Java 连接数据库总是报错
mysql账号密码是正确的,但是一直报账号密码错误. 报错信息: java.sql.SQLException: Access denied for user 'root'@'localhost' (u ...
- python使用阿里云oss-sdk
python使用阿里云oss-python-sdk 请访问github获取源码 安装 pip install oss2 安装验证 >>> import oss2 >>&g ...
- mongodb 指令
db.xxx.stats() 查看表的大小 db.xxx.remove({'endtime':{'$lte':ISODate('2018-10-01')}}) 删除小于等于固定时间的数据. db.us ...
- Linux服务器架设篇,Windows中的虚拟机linux上不了外网怎么办?
1.将电脑的网线口直连路由器内网接口(确保该路由器可以直接正常上网,切记不可以使用宽带连接和无线网连接). 2.在实体机电脑可以上网的前提下,在命令框窗口输入 ipconfig 3.记录下电脑以太网的 ...
- 从零开始实现放置游戏(十三)——实现战斗挂机(4)添加websocket组件
前两张,我们已经实现了登陆界面和游戏的主界面.不过游戏主界面的数据都是在前端写死的文本,本章我们给game模块添加websocket组件,实现前后端通信,这样,前端的数据就可以从后端动态获取到了. 一 ...
- python的int float if...else
# 字符串 string 单引号 ‘ ’ 双引号 “ ”-包含的 app = 'dongt woory' 外面单引号里面可以双引号,外面双引号,里面也可以单引号 app ='你是真的“好看”吗' ...