移动端Ionic App 资讯上下循环滚动的实现代码(跑马灯效果)


Posted in Javascript onAugust 29, 2017

在ionic App中遇到一个文字上下循环滚动的效果实现,网上查了之后才知道有个通俗的名字-跑马灯。

这里借助了jQuery库的选择器和动画函数,并且把jquery的操作封装到指令里。先看指令代码:

angular.module('starter') 
  .directive('slideScroll', function ($window, $timeout) { 
    return { 
      restrict: 'AE', 
      link: function (scope, element, attr) { 
        var _scrollHeight = 40; 
        var _newsLen = 3; 
        var index = 0; 
        setInterval(function () { 
          index += 1; 
          if (index > _newsLen) { 
            index = 0; 
            $(".news-right ul").css({ 
              top: 0 
            }) 
          } else { 
            $(".news-right ul").animate({ 
              top: -_scrollHeight * index - 10 * index 
            }, 500); 
          } 
        }, 2000) 
      } 
    }; 
  });

滚动的高度scrollHeight设置为40px,三组文字newsLen循环,每组两行文字。每隔2000ms,ul列表向上移动固定距离,top值为(_scrollHeight + 10)* index 的长度。

Html 代码是这样的:

<div class="news-right" ui-sref="newsList"> 
   <ul slide-scroll> 
      <li class="news-box" ng-repeat="row in dataArr"> 
        <p ng-repeat="item in row">{{item.title.length <= 19 ? item.title : item.title.slice(0, 19) + '...'}}</p> 
      </li> 
      <li> 
         <p ng-repeat="item1 in dataArr[0]">{{item1.title.length <= 19 ? item1.title : item1.title.slice(0, 19) + '...'}}</p> 
      </li> 
   </ul> 
</div>

这里对文字做了简单的处理,字符串超过19,会以“...”的形式显示。

Css 样式表是这样的:

.news-right { 
  position: absolute; 
  height: 40px; 
  left: 100px; 
  top: 10px; 
  right: 0; 
  color: rgb(65, 65, 65); 
  overflow: hidden; 
}  
.news-right ul{ 
  width: 100%; 
  position: absolute; 
  top: 0; 
  left: 0; 
} 
.news-right p { 
  padding: 0; 
  line-height: 15px; 
  text-overflow: ellipsis; 
  box-sizing: border-box; 
  white-space: nowrap; 
  font-size: 13px; 
}

总结

以上所述是小编给大家介绍的移动端Ionic App 资讯上下循环滚动的实现代码,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!

Javascript 相关文章推荐
Javascript实现的类似Google的Div拖动效果代码
Aug 09 Javascript
js获取input标签的输入值实现代码
Aug 05 Javascript
js仿黑客帝国字母掉落效果代码分享
Nov 08 Javascript
json传值以及ajax接收详解
May 24 Javascript
JavaScript编写带旋转+线条干扰的验证码脚本实例
May 30 Javascript
jQuery 操作input中radio的技巧
Jul 18 Javascript
javascript 动态脚本添加的简单方法
Oct 11 Javascript
js定时器实例分享
Dec 20 Javascript
将angular-ui的分页组件封装成指令的方法详解
May 10 Javascript
Vue2.0 从零开始_环境搭建操作步骤
Jun 14 Javascript
vue中element 上传功能的实现思路
Jul 06 Javascript
vue+iview/elementUi实现城市多选
Mar 28 Javascript
基于jstree使用AJAX请求获取数据形成树
Aug 29 #Javascript
基于jQuery的左滑出现删除按钮的示例
Aug 29 #jQuery
jQuery实现简单的计时器功能实例分析
Aug 29 #jQuery
Vue2.0权限树组件实现代码
Aug 29 #Javascript
基于Vue实现后台系统权限控制的示例代码
Aug 29 #Javascript
jQuery动态添加.active 实现导航效果代码思路详解
Aug 29 #jQuery
laravel5.4+vue+element简单搭建的示例代码
Aug 29 #Javascript
You might like
php print EOF实现方法
2009/05/21 PHP
php中加密解密DES类的简单使用方法示例
2020/03/26 PHP
基于jquery的自定义鼠标提示效果 jquery.toolTip
2010/11/14 Javascript
JavaScript入门之基本函数详解
2011/10/21 Javascript
javascript window.open打开新窗口后无法再次打开该窗口问题的解决方法
2014/04/12 Javascript
JavaScript中获取样式的原生方法小结
2014/10/08 Javascript
深入理解JavaScript系列(42):设计模式之原型模式详解
2015/03/04 Javascript
JavaScript实现带箭头标识的多级下拉菜单效果
2015/08/27 Javascript
纯JS前端实现分页代码
2016/06/21 Javascript
使用vue2实现带地区编号和名称的省市县三级联动效果
2018/11/05 Javascript
[40:55]DOTA2上海特级锦标赛主赛事日 - 2 败者组第二轮#4Newbee VS Fnatic
2016/03/03 DOTA
详解Python中的装饰器、闭包和functools的教程
2015/04/02 Python
python用reduce和map把字符串转为数字的方法
2016/12/19 Python
用Python实现随机森林算法的示例
2017/08/24 Python
5款非常棒的Python工具
2018/01/05 Python
Python3中lambda表达式与函数式编程讲解
2019/01/14 Python
Django外键(ForeignKey)操作以及related_name的作用详解
2019/07/29 Python
python识别文字(基于tesseract)代码实例
2019/08/24 Python
Python进程,多进程,获取进程id,给子进程传递参数操作示例
2019/10/11 Python
Pytorch使用MNIST数据集实现基础GAN和DCGAN详解
2020/01/10 Python
Django实现将views.py中的数据传递到前端html页面,并展示
2020/03/16 Python
Python结合Window计划任务监测邮件的示例代码
2020/08/05 Python
html5记忆翻牌游戏实现思路及代码
2013/07/25 HTML / CSS
清除canvas画布内容(点擦除+线擦除)
2020/08/12 HTML / CSS
Under Armour美国官网:美国知名高端功能性运动品牌
2016/09/05 全球购物
Pretty Little Thing爱尔兰:时尚女性服饰
2017/03/27 全球购物
Sneaker Studio捷克:购买运动鞋
2018/07/08 全球购物
《二泉映月》教学反思
2014/04/15 职场文书
奥巴马胜选演讲稿
2014/05/15 职场文书
企业诚信承诺书
2014/05/23 职场文书
计算机毕业大学生求职信
2014/06/26 职场文书
研究生简历自我评价范文
2014/09/13 职场文书
承兑汇票转让证明怎么写?
2014/11/30 职场文书
小学元宵节活动总结
2015/02/06 职场文书
Python中使用Lambda函数的5种用法
2021/04/01 Python
OpenCV-Python实现人脸美白算法的实例
2021/06/11 Python