大家都知道,做html页面时,为了提升网页的用户体验,我们需要在网页中加入一些特效,比如单行区域文字上下滚动就是经常用到的特效。如下图示效果:

<html>
<head>
<title>js实现文字上下滚动效果</title>
<style type="text/css">
#flinks{width:500px;} /* 文字上下滚动 */
.scroll-box{position:relative;top:0;overflow:hidden;padding:0 10px;display:inline-block;height:29px;line-height:29px}
.scroll-box.on{background:#fff;z-index:2;overflow:auto;height:auto !important;box-shadow:1px 1px 10px #888}
.scroll-box.on li{top:0 !important;border-bottom:1px dotted #ccc}
.scroll-box li{position:relative;}
.scroll-box a{display:inline-block;white-space:nowrap;padding-top:0 !important;padding-bottom:0 !important;margin-top:0 !important;margin-bottom:0 !important;}
.scroll-mask{z-index:1;display:none;position:fixed;top:0;right:0;bottom:0;left:0;display:none;background-color:rgba(0,0,0,0.5);filter:progid:DXImageTransform.Microsoft.gradient(startColorstr=#7F000000,endColorstr=#7F000000)}
.scroll-mask.on{/*display:block;*/}
</style>
<script type="text/javascript" src="http://libs.baidu.com/jquery/1.7.1/jquery.min.js"></script>
<script type="text/javascript"> (function ($) {
/* 单行文字上下滚动 */
$.fn.adScroll = function (options) {
// 默认配置
var scrollOptions = {
interval: 6000
};
$.extend(scrollOptions, options); $(this).each(function () {
var scrollObj = $(this);
// 单行内容无需滚动显示,取消初始化
var totalHeight = 0;
scrollObj.find('li').each(function () { totalHeight += $(this).height() });
var liSize = Math.round(totalHeight / scrollObj.height());
if(liSize <= 1) return; // 初始化开始
scrollObj.attr('index', '0');
// 重置滚动容器高度
scrollObj.height(scrollObj.find('a').outerHeight(true));
// 重置滚动项 li 高度
scrollObj.find('li').size() > 1 && scrollObj.find('li').height(scrollObj.height());
// 外层容器,辅助定位
var containerObj = $('<div>').height(scrollObj.outerHeight(true));
scrollObj.wrap(containerObj);
// 遮罩层
var maskObj = $('<div>').addClass('scroll-mask');
scrollObj.after(maskObj); setInterval(function () {
if (!scrollObj.hasClass('on')) {
// 所有 li 高度之和除以容器高度
var liTotalHeight = 0;
scrollObj.find('li').each(function () { liTotalHeight += $(this).height() });
var size = Math.round(liTotalHeight / scrollObj.height());
var curIndex = parseInt(scrollObj.attr('index'));
var next = curIndex + 1 >= size ? 0 : curIndex + 1;
if (next == 0) {
scrollObj.find('li').animate({ top: 0 }, 'slow');
} else {
scrollObj.find('li').animate({ top: '-=' + scrollObj.height() }, 'slow');
}
scrollObj.attr('index', next);
}
}, scrollOptions.interval); // 滚动列表可以被展开
if(scrollObj.hasClass('box-expand')) {
// 切换
scrollObj.mouseover(function () {
scrollObj.css('top', scrollObj.find('li').css('top'));
scrollObj.addClass('on');
maskObj.addClass('on');
}).mouseout(function () {
scrollObj.css('top', 0);
scrollObj.removeClass('on');
maskObj.removeClass('on');
});
}
});
};
})(jQuery); $(function(){
if ($('.scroll-box').size() > 0) {
$('.scroll-box').adScroll({interval: 2000});
}
}) </script>
</head>
<body>
<h1>js实现文字上下滚动效果</h1>
<h2>文字滚动示例一:</h2>
<p>适用于单行区域文字或图片上下滚动广告</p>
<ul class="scroll-box box-expand">
<li><a href="#" target="_blank">双十一大额优惠券,领券折上折!</a></li>
<li><a href="#" target="_blank" >※ 新人福利社,超级好货0元购 ※</a></li>
<li><a href="#" target="_blank">韩都衣舍,闺蜜衣橱 — 天猫女装销量冠军</a></li>
<li><a href="#" target="_blank" >20181031期福利红包,订单提交时抵现使用</a></li>
<li><a href="#" target="_blank">淘宝网优惠,官方活动一网打尽</a></li>
</ul> <h2>文字滚动示例二:</h2>
<p>适合于单行区域友情链接上下滚动</p>
<ul id="flinks" class="scroll-box">
<li>
<a href="#" target="_blank">友情链接1</a>
<a href="#" target="_blank">友情链接2</a>
<a href="#" target="_blank">友情链接3</a>
<a href="#" target="_blank">友情链接4</a>
<a href="#" target="_blank">友情链接5</a>
<a href="#" target="_blank">友情链接6</a>
<a href="#" target="_blank">友情链接7</a>
<a href="#" target="_blank">友情链接8</a>
<a href="#" target="_blank">友情链接9</a>
<a href="#" target="_blank">友情链接10</a>
</li>
</ul>
</body>
</html>

要点提示:

1、特效初始化代码

$('.scroll-box').adScroll({interval: 2000});
2、特效代码结构

<ul class="scroll-box box-expand">
<li>........</li>
<li>........</li>
</ul>
3、样式名称 box-expand 控制鼠标移上时是否显示所有内容

特效源码源自:领券网 www.i075.com

js实现文字上下滚动效果的更多相关文章

  1. js 实现文字列表滚动效果

    今天要实现抽奖名单在首页滚动展示的效果,就用js写了一个,代码如下: html代码: <style type="text/css"> *{margin:;padding ...

  2. js标题文字向上滚动

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xht ...

  3. jquery实现文字上下滚动效果

    文字上下滚动是经常用到的js效果,这里介绍一种上下渐隐渐出的文字展现效果! 代码实现很简单,只需要引入jquery就可以. 代码如下: <!DOCTYPE> <head> &l ...

  4. Vue开发组件之替代marquee标签,超出宽度文字横向滚动效果

    一.npm 安装 如果你想安装插件(自己写的)安装 install dependencies npm i marquee-components 使用 在main.js引入 import marquee ...

  5. js 实现单行文本滚动效果

    js 代码如下: /***************滚动场次开始*****************/ function ScrollText(content, btnPrevious, btnNext, ...

  6. jquery实现多行文字图片滚动效果

    今儿分享一个jquery实现多行滚动效果. 我看一些论坛网站上面,公告处用的较多. 代码如下 复制代码 // 多行滚动(function($){$.fn.extend({Scroll:function ...

  7. js实现文字横向滚动

    页面布局      <div id="scroll_div" class="fl">         <div id="scroll ...

  8. TextView实现文字水平滚动效果

    有时候我们使用TextView显示文本,只想把所有内容用一行显示出来,但是一行又显示不完,就需要让文本实现水平滚动的效果. 具体实现方法如下: 1,实现自定义TextView并实现isFocused( ...

  9. jquery文字纵向滚动效果(带间隔停留)

    <script type="text/javascript"> //文字纵向滚动 $(function() { var $this = $("#quotati ...

随机推荐

  1. 手撕面试官系列(十):面试必备之常问Dubbo29题+MySQL55题

    Dubbo专题 (面试题+答案领取方式见侧边栏) 1.Dubbo 支持哪些协议,每种协议的应用场景,优缺点?2.Dubbo 超时时间怎样设置?3.Dubbo 有些哪些注册中心?4.Dubbo 集群的负 ...

  2. c++11多线程记录4:死锁

    简单示例 举个例子,桌上有一支笔和一张纸,小A和小B都要拿到纸笔写字 小A拿了笔,小B拿了纸,这时就形成了死锁(两人都不愿意让出纸笔). 其实只要稍加控制就可以避免这种情况:规定必须先拿到纸再能去尝试 ...

  3. MySQL多表查询,Navicat使用,pymysql模块,sql注入问题

    一.多表查询 #建表 create table dep( id int, name varchar(20) ); create table emp( id int primary key auto_i ...

  4. STM32 EV1527无线通信(433)

    EV1527无线通信 先说一下这个通信协议的数据格式,这个图片是我在手册里截的. 大家按照单片机类型计算周期,我的是STM32f103vb (4CLK大致等于350um) 发送时按照 先发同步码后发D ...

  5. GO指南练习:切片

    最近开始GO语言的学习,在GO指南中练习到切片这个题目 练习:切片 实现 Pic.它应当返回一个长度为 dy 的切片,其中每个元素是一个长度为 dx,元素类型为 uint8 的切片.当你运行此程序时, ...

  6. 在Go中简单实现HTTP服务中间件

    通常一个简单http服务框架,就是注册一堆路由,然后根据路由调用不同的逻辑去处理. 但实际上可能有一些统一的处理对几乎所有的路由都涉及到,比如日志,比如权限等等. 那么这个时候搞一个中间做预处理,是一 ...

  7. pytest_函数传参和firture传参数request

    前言为了提高代码的复用性,我们在写用例的时候,会用到函数,然后不同的用例去调用这个函数. 比如登录操作,大部分的用例都会先登录,那就需要把登录单独抽出来写个函数,其它用例全部的调用这个登陆函数就行. ...

  8. kie-api介绍和使用

    参考:KIE kie在drools jbpm uberfire里广泛被使用,下面对kie-api中的几个重要组件做下简单介绍 maven依赖 <dependency> <groupI ...

  9. windows桌面远程连接突然不能双向复制文件

    远程桌面连接windows 2008,突然无法在本地和服务器之间互相复制文件.根据微软的说明,由rdpclip.exe进程来控制,打开远程服务器的任务管理器,看到rdpclip.exe进程存在,即可进 ...

  10. Windows 2003 服务器 关闭IIS中FTP匿名访问

    控制面板 –> 管理工具 –> Internet信息服务管理器打开后左侧选择相应的FTP站点右击 –> 属性 –> 安全帐户允许匿名连接 前面的√取消掉,点击确定完成