初衷:

  学习完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封装一个包含图片的跑马灯组件的更多相关文章

  1. vue.js 作一个用户表添加页面----初级

    使用vue.js 制作一个用户表添加页面,实际上是把原来需要使用js写的部分,改写成vue.js的格式 首先,想象一下,先做思考,我们要添加用户表,设涉及到哪些数据,一个是用户id,一个是用户名,一个 ...

  2. ionic js 滑动框ion-slide-box 滑动框是一个包含多页容器的组件,每页滑动或拖动切换

    ionic 滑动框 ion-slide-box 滑动框是一个包含多页容器的组件,每页滑动或拖动切换: 效果图如下: 用法 <ion-slide-box on-slide-changed=&quo ...

  3. 使用 JS 实现图片左右跑马灯

    Ø  前言 之前写了一篇使用 JS 实现文字上下跑马灯,现在乘热打铁在把图片左右跑马灯一起贴出来,不多说直接看代码. 1.   首先定义 css 样式 <style type="tex ...

  4. vue中封装一个全局的弹窗js

    /** * Created by yx on 2017/12/21. */ export default { /** * 带按钮的弹框 * <!--自定义提示标题,内容,单个按钮事件--> ...

  5. 用Vue.js开发一个电影App的前端界面

    我们要构建一个什么样的App? 我们大多数人使用在线流媒体服务(如Netflix)观看我们最喜欢的电影或者节目.这篇文章将重点介绍如何通过使用vue.js 2 建立一个类似风格的电影流媒体WEB交互界 ...

  6. 结合Vue.js的前端压缩图片方案

    这是一个很简单的方案.嗯,是真的. 为什么要这么做? 在移动Web蓬勃发展的今天,有太多太多的应用需要让用户在移动Web上传图片文件了,正因如此,我们有些困难必须去攻克: 低网速下上传进度缓慢,用户体 ...

  7. Vue.js实现一个SPA登录页面的过程

    技术栈 vue.js 主框架 vuex 状态管理 vue-router 路由管理 一般过程 在一般的登录过程中,一种前端方案是: 检查状态:进入页面时或者路由变化时检查是否有登录状态(保存在cooki ...

  8. 用Vue.js搭建一个小说阅读网站

    目录 1.简介 2.如何使用vue.js 3.部署api服务器 4.vue.js路由配置 5.实现页面加载数据 6.测试vue项目 7.在正式环境部署 8.Vue前端代码下载 1.简介 这是一个使用v ...

  9. Vue.js写一个SPA登录页面的过程

    技术栈 vue.js 主框架 vuex 状态管理 vue-router 路由管理 一般过程 在一般的登录过程中,一种前端方案是: 检查状态:进入页面时或者路由变化时检查是否有登录状态(保存在cooki ...

随机推荐

  1. POJ - 3255 SPFA+邻接表求次短路径

    题意:给出m条边 , n个顶点,u [ i ]到v [ i ] 的距离w [ i ],求除了最短路的那条最短的边的长度. 思路:之前有做过相似的题,使用迪杰斯特拉算法求单源最短路径,并且记录路径,枚举 ...

  2. 一夜搞懂 | JVM 字节码执行引擎

    前言 本文已经收录到我的 Github 个人博客,欢迎大佬们光临寒舍: 我的 GIthub 博客 学习导图 一.为什么要学习字节码执行引擎? 代码编译的结果从本地机器码转变为字节码,是存储格式发展的一 ...

  3. 从 Socket 编程谈谈 IO 模型(三)

    快过年啦,估计很多朋友已在摸鱼的路上.而我为了兄弟们年后的追逐,却在苦苦寻觅.规划,导致文章更新晚了些,各位猿粉谅解. 上期分享,我们结合新春送祝福的场景,通过一坨坨的代码让 BIO.NIO 编程过程 ...

  4. 新手必学linux文本文件编辑命令 vi vim.....

    作为一名Linux新手小白,今天就和大家简单地了解一下Linux的Vim文本编辑器的使用. Vim文本编辑器     vim编辑器的三大模式——命令模式.编辑模式和末行模式            命令 ...

  5. 简单实现Win10炫酷下滑关机

    实现效果如下图,鼠标左键按下下拉关机: 先说下实现思路和实现过程(包括失败过程),不想了解的可直接往下拉查看红色字体标注的最终实现方法. 首先实现下滑关机的Windows自带的一个功能(程序)Slid ...

  6. 泛型代码中的 default 关键字

    在泛型类和泛型方法中会出现的一个问题是,如何把缺省值赋给参数化类型,此时无法预先知道以下两点: l        T将是值类型还是引用类型 l        如果T是值类型,那么T将是数值还是结构 对 ...

  7. Navicat安装教程

    Navicat安装教程 1.下载: 链接:https://pan.baidu.com/s/1uLlstPYrsjaNhZqVu9aFfQ 提取码:393r 2.下载完成之后如图所示: 首先安装第二个, ...

  8. node.js代码

    // 1. 引入 express var express = require('express'); var formidable = require('formidable'); var mysql ...

  9. Linux网络安全篇,认识防火墙(一)

    一.概念 防火墙分为软件防火墙和硬件防火墙.我们的主要讨论范围为软件防火墙. 软件防火墙又分为网络型和单一型的管理. 1.单一主机型防火墙 (1)数据包过滤型的Netfilter (2)依据服务软件程 ...

  10. MAC 上brew 更新 出错

    在MAC上brew update的时候出现报错:Error: /usr/local must be writable! 错误,在该文章中也给出解决办法(sudo chown -R $(whoami) ...