[前端] js实现新闻轮播效果

3166 0
Honkers 2022-10-21 15:24:05 | 显示全部楼层 |阅读模式
本文实例为大家分享了js实现新闻轮播效果的具体代码,供大家参考,具体内容如下
原生js实现新闻轮播效果,附详细注释
  1. <!DOCTYPE html>
  2. <html lang="en">
  3. <head>
  4.   <meta charset="UTF-8">
  5.   <meta name="viewport" content="width=device-width, initial-scale=1.0">
  6.   <title>Document</title>
  7. </head>
  8. <body>
  9.   <input type="text" id="input">
  10.   <button id="btn">插入</button>
  11.   <ul id="box"></ul>
  12.   <script>
  13.     // 定义数组
  14.     var news = ['111111111111','2222222222222222222','33333333333333'];
  15.     // 获取元素
  16.     var input = document.getElementById('input');
  17.     var btn = document.getElementById('btn');
  18.     var box = document.getElementById('box');
  19.     // 把原有的新闻显示在页面中
  20.     carousel();
  21.     // 把渲染结构的内容封装为一个函数
  22.     function carousel(){
  23.       // 定义一个空字符串
  24.       var str = '';
  25.       // 遍历数组,把数组里面的每一个值都重复拿出来添加到 li 标签里再赋值给str
  26.       news.forEach(function(item){
  27.         str +=`<li>${item}</li>`;
  28.       });
  29.       // 把 str 的内容给到 box 结构里
  30.       box.innerHTML = str;
  31.     }
  32.     // 点击添加的时候 把 用户输入的内容添加到数组中,再次渲染结构
  33.     btn.onclick = function(){
  34.       // 为了良好的用户体验 输入框中的值不能为空
  35.       if(!input.value){
  36.         // 弹出提示框
  37.         alert('输入框不能为空');
  38.         // 这里 return 是中断循环的意思
  39.         return;
  40.       }
  41.       // 把内容添加到数组中
  42.       news.unshift(input.value);
  43.       // 页面中新闻只能为5条,如果超过5条,把5条之后的数据删除
  44.       if(news.length>5){
  45.         // 只截取页面最新的5条新闻
  46.         news.splice(5);
  47.       }
  48.       // 调用 渲染结构
  49.       carousel();
  50.       // 插入新闻完成后输入框赋空
  51.       input.value = '';
  52.     }
  53.     /*
  54.     【1】间隔执行函数,每隔多少时间去执行一次函数,这里 1000 指的是 1s
  55.         setInterval(function(){
  56.           你需要执行的代码
  57.         },1000)
  58.     */
  59.     // 设置定时器 新闻的滚动切换(把数组中的最后一条数据 截取出来放入数组中第一条),再次循环 渲染结构
  60.     setInterval(function(){
  61.       // pop() 在删除数组的最后一个元素 把删除的数据赋值给res
  62.       var res = news.pop();
  63.       // unshift() 在数组的最前面添加一个元素
  64.       news.unshift(res);
  65.       // 调用函数,再次渲染结构
  66.       carousel();
  67.       // 定时,时长设置为2s
  68.     },2000);
  69.   </script>
  70. </body>
  71. </html>
复制代码
效果:
初始:


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


插入大于5条:


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


以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持中国红客联盟。

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有账号?立即注册

×
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

Honkers

特级红客

关注
  • 3159
    主题
  • 36
    粉丝
  • 0
    关注
这家伙很懒,什么都没留下!

中国红客联盟公众号

联系站长QQ:5520533

admin@chnhonker.com
Copyright © 2001-2025 Discuz Team. Powered by Discuz! X3.5 ( 粤ICP备13060014号 )|天天打卡 本站已运行