css实现div内文字自动滚动

网上找了好久,终于找到了个能实现的,把它整理一下。
需求:表格内字体过长实现自动滚动
实现思路如下:
html:

<div class="item-column" style="background: rgb(12, 87, 154); width: 18%; height: 60px; line-height: 60px;"><p class="scrollDiv">让我更热个热更热个人人人歌更让人热啊隔热个人</p></div>

css:

.item-column {
  height: 200px;
  width: 300px;
  overflow:hidden;
}

.item-column>p {
    white-space: nowrap; //设置不换行
}

.scrollDiv {
    position: relative;
    animation: scroll 30s infinite linear; //滚动速度,值越大越慢
}

@keyframes scroll {
	//滚动范围
    0% { left: 5%; }
    100% { left: -100%; }
}

js:

//根据class获取所有的集合,然后遍历判断实际内容长度是否大于可视区域,是的话就加上带滚动效果的class
 var itemColumns = document.getElementsByClassName("item-column");
                for (let i = 0; i < itemColumns.length; i++) {
                    var column = itemColumns[i];
                    if (column.scrollWidth > column.clientWidth) {
                        var scrollColum = column;
                        var d = column.scrollWidth - column.clientWidth;
                    	$(column).find("p").addClass("scrollDiv");
                    }
                }

效果图:
在这里插入图片描述

  • 2
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值