js实现新闻轮播效果

Octavia ·
更新时间:2024-11-10
· 595 次阅读

本文实例为大家分享了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不显示呢,这是因为可能插入的数据类型为整型,在遍历数组的时候跑到前面位置所以不显示



js实现 轮播 js

需要 登录 后方可回复, 如果你还没有账号请 注册新账号