vue内容横向循环滚动_vue文字横向滚动公告

本文介绍了如何使用Vue创建一个文字横向无缝滚动的组件。通过HTML布局、CSS样式设置和JavaScript处理滚动逻辑,实现了一个简单的Vue文字滚动公告组件。详细步骤包括设置HTML结构,CSS样式以确保平滑滚动,以及在Vue中编写JavaScript方法来控制滚动速度和回滚起点。
摘要由CSDN通过智能技术生成

需求

最新项目需要一个文字横向滚动效果,

vue 文字横向无缝走马灯组件

写的很详细,记录下来,广播出去。

解决方案

1、 HTML

先建一个div层作为公告显示区,里面包裹一个公告列表(ul);

2、 CSS

每条公告信息(li)的margin必须设置‘px’单位,否则要转换,后面js中回到起点还要用到这个值。

body,div,html,img,li,ul{margin:0;padding:0;border:0}

li{list-style:none}

.advert-top{position:relative;display:flex;width:100%;height:.88rem;background:linear-gradient(270deg,rgba(80,175,255,1) 0,rgba(13,132,248,1) 48%,rgba(55,159,248,1) 86%,rgba(81,176,255,1) 100%);color:#fff;font-size:.26rem;align-items:center}

.ico-horn{display:flex;width:.88rem;height:.88rem;justify-content:center;align-items:center}

.ico-horn>img{width:.32rem;height:.32rem}

/* 以下代码与滚动相关 */

.marquee-wrap{position:relative;display:flex;overflow:hidden;width:100%;height:100%}

.marquee-box{position:absolute;top:50%;display:flex;white-space:nowrap;transform:translateY(-50%)}

.marquee-list{margin-right:10px} /* 此处“px”方便回到起点 */

.marquee-list span{padding:0 .04rem;color:#ffe17b;font-weight:700}

3、 JavaScript

var vm = new Vue({

el: '#app',

data: {

ico_horn: 'https://img.alicdn.com/tfs/TB1zwftaPrguuRjy0FeXXXcbFXa-16-16.png',

message: "全球新冠肺炎确诊病例超45万,死亡人数破2万!",

},

mounted: function () {

// 延时滚动

setTimeout(() => {

this.runMarquee()

}, 1000)

},

methods: {

runMarquee() {

// 获取文字 计算后宽度

var width = document.getElementById('marquee').getBoundingClientRect().width,

marquee = document.getElementById('marquee-box'),

disx = 0; // 位移距离

//设置位移

setInterval(() => {

disx--; // disx-=1; 滚动步长

if (-disx >= width) {

disx = 10; // 如果位移超过文字宽度,则回到起点 marquee-list的margin值

}

// marquee.style.transform = 'translateX(' + disx + 'px)'

marquee.style.left = disx + 'px'

}, 30) //滚动速度

}

}

});

// JavaScript Document

(function px2rem(doc, win) {

var docEl = doc.documentElement,

resizeEvt = 'orientationchange' in window ? 'orientationchange' : 'resize',

recalc = function () {

var clientWidth = docEl.clientWidth;

if (!clientWidth) return;

docEl.style.fontSize = 100 * (clientWidth / 750) + 'px';

/*

* 100 -> html,body { font-size:100px; }

* 750 -> 此处以 iPhone6 两倍设计稿 宽度750px 布局页面

* 根据具体情况改变这两个数值

*/

};

if (!doc.addEventListener) return;

// 窗口大小发生变化,初始化

win.addEventListener(resizeEvt, recalc, false);

doc.addEventListener('DOMContentLoaded', recalc, false);

//防止在html未加载完毕时执行,保证获取正确的页宽

setTimeout(function () {

px2rem(doc, win);

}, 200);

})(document, window);

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值