用原生JS怎么写新闻轮播的效果,代码是什么
Admin 2022-08-08 群英技术资讯 1240 次浏览
本篇内容介绍了“用原生JS怎么写新闻轮播的效果,代码是什么”的有关知识,在实际项目的操作过程或是学习过程中,不少人都会遇到这样的问题,接下来就让小编带大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!原生js实现新闻轮播效果,附详细注释
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Document</title>
</head>
<body>
<input type="text" id="input">
<button id="btn">插入</button>
<ul id="box"></ul>
<script>
// 定义数组
var news = ['111111111111','2222222222222222222','33333333333333'];
// 获取元素
var input = document.getElementById('input');
var btn = document.getElementById('btn');
var box = document.getElementById('box');
// 把原有的新闻显示在页面中
carousel();
// 把渲染结构的内容封装为一个函数
function carousel(){
// 定义一个空字符串
var str = '';
// 遍历数组,把数组里面的每一个值都重复拿出来添加到 li 标签里再赋值给str
news.forEach(function(item){
str +=`<li>${item}</li>`;
});
// 把 str 的内容给到 box 结构里
box.innerHTML = str;
}
// 点击添加的时候 把 用户输入的内容添加到数组中,再次渲染结构
btn.onclick = function(){
// 为了良好的用户体验 输入框中的值不能为空
if(!input.value){
// 弹出提示框
alert('输入框不能为空');
// 这里 return 是中断循环的意思
return;
}
// 把内容添加到数组中
news.unshift(input.value);
// 页面中新闻只能为5条,如果超过5条,把5条之后的数据删除
if(news.length>5){
// 只截取页面最新的5条新闻
news.splice(5);
}
// 调用 渲染结构
carousel();
// 插入新闻完成后输入框赋空
input.value = '';
}
/*
【1】间隔执行函数,每隔多少时间去执行一次函数,这里 1000 指的是 1s
setInterval(function(){
你需要执行的代码
},1000)
*/
// 设置定时器 新闻的滚动切换(把数组中的最后一条数据 截取出来放入数组中第一条),再次循环 渲染结构
setInterval(function(){
// pop() 在删除数组的最后一个元素 把删除的数据赋值给res
var res = news.pop();
// unshift() 在数组的最前面添加一个元素
news.unshift(res);
// 调用函数,再次渲染结构
carousel();
// 定时,时长设置为2s
},2000);
</script>
</body>
</html>
效果:
初始:

插入数据(因为我们设置了轮播效果,所以新闻会一直滚动):

插入大于5条:

插入只显示数组的最新的五条数据,为什么第一条插入4510202不显示呢,这是因为可能插入的数据类型为整型,在遍历数组的时候跑到前面位置所以不显示

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
背景<img>加载错误解决方案内联事件全局img添加事件利用error事件捕获替换src方式的最优解CSS处理的最优解<img>加载超时解决方案嗅探切换Domain(CNAME)服务端下发Domai
SVG是一种图像文件格式,意思为可缩放的矢量图形,是现在比较流行的图像文件格式之一,使用SVG格式我们就能够直接使用代码来描绘图像。那么我们如果要在vue中引入svg图标,要怎么做呢?
Rxjs中处理和抓取错误是怎样的?在实际项目的操作过程或是学习过程中,不少人都会遇到这样的问题,接下来就让小编带大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!
js判断在哪个浏览器打开项目的方法,通过以下方法判断浏览器
这篇文章给大家分享的是JavaScript反转数组的方法。下文分享了使用for循环和push()方法和reverse()方法这两种,文中的示例代码有一定的参考价值,有需要的朋友可以了解看看,接下来就跟随小编一起学习一下吧。
成为群英会员,开启智能安全云计算之旅
立即注册关注或联系群英网络
7x24小时售前:400-678-4567
7x24小时售后:0668-2555666
24小时QQ客服
群英微信公众号
CNNIC域名投诉举报处理平台
服务电话:010-58813000
服务邮箱:service@cnnic.cn
投诉与建议:0668-2555555
Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008