[JS]手动实现一个横屏滚动公告js插件
前言
工作中要用到.在github上找的大部分都是竖屏滚动没办法只能自己手动写.
本来只是想随便实现一下的,结果一时兴起把它弄成了一个简单的小插件,开了个github仓库(希望路过点个星)



因为我自己就是用户,尽量简化了用户要做的操作.现在使用起来像是这个样子
<div id="notice">这是一个公告</div>
<!-- 依赖jquery -->
<script src="https://cdn.bootcss.com/jquery/2.2.4/jquery.min.js"></script>
<!-- 引入本库 -->
<script src="./assets/js/roll_notice.js"></script>
<script>
    roll_notice({ id: 'notice' })
</script>
思路
- 公告容器
宽度不定: 使用js动态计算宽度等数值 - 公告
不能换行: 设置white-space:nowrap,凸出去的部分用overflow:hidden掩藏 - 公告向左滚动: 只需
定时改变文字容器的left即可 - 实现循环滚动: 文字完全消失后将div移到公告容器的
末尾 - 代码可读性: 大量使用Promise取代回调
 
实现
大量使用ES6语法,不打算兼容IE
入口像是这样,详细可以看源码
return (option = {}) => {
  start(init(option))
}
												
											[JS]手动实现一个横屏滚动公告js插件的更多相关文章
- 一个无缝滚动的jquery插件
		
$.fn.imgscroll = function(o){ var defaults = { speed: 40, amount: 0, width: 1, dir: "left" ...
 - 【原创】使用JS封装的一个小型游戏引擎及源码分享
		
1 /** * @description: 引擎的设计与实现 * @user: xiugang * @time: 2018/10/01 */ /* * V1.0: 引擎实现的基本模块思路 * 1.创建 ...
 - Headroom.js – 快速响应用户的页面滚动操作
		
Headroom.js 是一个轻量级,高性能的JS插件(无依赖性!),允许你响应用户的滚动行为.Headroom.js 使您能够在适当的时候把元素融入视图,而其它时候让内容成为焦点.Headroom. ...
 - 《fullPage.js》创建全屏滚动的网站
		
插件介绍 fullPage.js是一个简单易用的插件,创建全屏滚动的网站(也被称为单页网站).它允许全屏滚动创建网站,以及添加内部滑块. 浏览器兼容性 主要功能 支持鼠标滚动 支持前进后退和键盘控制 ...
 - 一个简单用原生js实现的小游戏----FlappyBird
		
这是一个特别简单的用原生js实现的一个小鸟游戏,比较简单,适合新手练习 这是html结构 <!DOCTYPE html><html lang="en">&l ...
 - 页面中的平滑滚动——smooth-scroll.js的使用
		
正常的本页面锚链接跳转的时候跟PPT似的,特别生硬,用户体验非常差. 这时候我们就可以借助smooth-scroll.js这个插件,来实现本页面的平滑的跳转. 1首先,导入必须的JS文件 <sc ...
 - js - 移动端的超出滚动功能,附带滚动条,可解决弹层中滚动穿透问题。
		
背景: 弹层里边有可滚动区域时,在移动端的坑我就不多说了. 找了很多解决滚动穿透的方案,最终都不能完美解决. 一气之下自己js撸了一个. 效果图: 原理: 1.解决滚动穿透:通过给弹层绑定touchm ...
 - 一周一个小demo — vue.js实现备忘录功能
		
这个vue实现备忘录的功能demo是K在github上找到的,K觉得这是一个用来对vue.js入门的一个非常简单的demo,所以拿在这里共享一下. (尊重他人劳动成果,从小事做起~ demo原git ...
 - 一款很好用的页面滚动元素动画插件-AOS.JS
		
aos.js是一款效果超赞的页面滚动元素动画jQuery动画库插件.该动画库可以在页面滚动时提供28种不同的元素动画效果,以及多种easing效果.在页面往回滚动时,元素会恢复到原来的状态. 加载方法 ...
 
随机推荐
- $translate 的用法
			
translate 的用法 1.在html页面:文本的翻译 <h1 translate>hello world</h1> <h1 translate = 'hello w ...
 - Beta Scrum
			
听说 Beta Scrum Day 1
 - Build to win
			
UPDATE:看到周筠老师的评论里的链接,那版式真的非常舒服.我想想模仿模仿他的布局来看看,虽然感觉做的也不是太好.另外对博客内容稍作修改. 一.获得小黄衫的感受 很幸运能够获得"领骑衫&q ...
 - python实现k-近邻算法
			
参考:<机器学习实战>- Machine Learning in Action 一. 必备的包 实现此算法需要准备以下的包: • matplotlib,用于绘图 • numpy,数组处理库 ...
 - Flask 学习 十  博客文章
			
提交和显示博客文章 app/models.py 文章模型 class Post(db.Model): __tablename__ = 'posts' id = db.Column(db.Integer ...
 - github感悟
			
刚学GitHub进入网页全英文的,感觉很惊讶,自己竟然要在全英文的网站上学习,虽然是英文的但并不感觉有压力,可能之前用eclipse就是全英文的现在除了惊讶,没太多的想法.然后就是我的GitHub地址 ...
 - 前端面试题之html
			
1.简述<!DOCTYPE> 的作用,标准模式和兼容模式各有什么区别? <!DOCTYPE> 位于文档的第一行,告知浏览器使用哪种规范. 如果不写DOCTYPE,浏览器会进入混 ...
 - Echarts柱状图实现不同颜色渐变色
			
第一次写文,只是想记录一下自己平时发现的小功能,这篇主要是实现echarts柱状图,每个柱子实现不同颜色的渐变色,也是第一次接触echarts,后台使用ssm,前台是extjs,直接上效果图 直接上j ...
 - app测试中遇到问题总结
			
工作总结: 1 这两天由于工作,需要进行抓包,使用了Charles,fidder,发现一个坑点: charles没有抓到返回值的时候,默认是不在列表显示请求信息的,能不能设置,我就不知道了,但是可以在 ...
 - 原生Ajax用法——一个简单的实例
			
Ajax全名(Asynchronous(异步) JavaScript and XML )是可以实现局部刷新的 在讲AJax之前我们先用简单的实例说一下同步和异步这个概念 /*异步的概念(就是当领导有一 ...