js实现新闻轮播效果

 更新时间:2022年07月13日 15:37:16   作者:混度思绪  
这篇文章主要为大家详细介绍了js实现新闻轮播效果,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

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

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

相关文章

  • JavaScript实现像雪花一样的Hexaflake分形

    JavaScript实现像雪花一样的Hexaflake分形

    这篇文章主要介绍了JavaScript实现像雪花一样的Hexaflake分形,文中示例代码非常详细,帮助大家更好的理解和学习,感兴趣的朋友可以了解下
    2020-07-07
  • 用javascript调出windows色版的代码

    用javascript调出windows色版的代码

    用javascript调出windows色版的代码...
    2007-07-07
  • JS生成随机打乱数组的方法示例

    JS生成随机打乱数组的方法示例

    这篇文章主要介绍了JS生成随机打乱数组的方法,涉及javascript数组随机排序的相关操作技巧,需要的朋友可以参考下
    2017-12-12
  • Three.js加载外部模型的教程详解

    Three.js加载外部模型的教程详解

    这篇文章主要介绍了Three.js外部模型加载的教程详解,在文章给大家补充介绍了three.js 外部模型加载json的方法,非常不错,具有参考借鉴价值,需要的朋友可以参考下
    2017-11-11
  • JS图片懒加载的优点及实现原理

    JS图片懒加载的优点及实现原理

    这篇文章主要介绍了JS图片懒加载的优点及实现原理,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2020-01-01
  • canvas实现钟表效果

    canvas实现钟表效果

    本文主要分享了canvas实现钟表效果的示例代码。具有很好的参考价值,下面跟着小编一起来看下吧
    2017-02-02
  • Javascript之旅 对象的原型链之由来

    Javascript之旅 对象的原型链之由来

    本人是Javascript菜鸟,下面是前几天学习Javascript的旅程心得,希望对和我一样的入门者有点用,也希望高手批评指正。
    2010-08-08
  • 通过实例解析JavaScript常用排序算法

    通过实例解析JavaScript常用排序算法

    这篇文章主要介绍了通过实例解析JavaScript常用排序算法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2020-09-09
  • JSON字符串操作移除空串更改key/value的介绍

    JSON字符串操作移除空串更改key/value的介绍

    今天小编就为大家分享一篇关于JSON字符串操作移除空串更改key/value的介绍,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看吧
    2019-01-01
  • JavaScript预解析及相关技巧分析

    JavaScript预解析及相关技巧分析

    这篇文章主要介绍了JavaScript预解析及相关技巧,结合实例形式分析了JavaScript与解析的原理,步骤与相关技巧,需要的朋友可以参考下
    2016-04-04

最新评论