angularjs实现文字上下无缝滚动特效代码
程序员文章站
2023-11-13 12:15:34
最近没有项目做,于是闲暇之余学习了下angularjs知识,然后写了一个文字上下无缝滚动的例子,主要写的是一个小小的指令。
css代码:
主要控制样式...
最近没有项目做,于是闲暇之余学习了下angularjs知识,然后写了一个文字上下无缝滚动的例子,主要写的是一个小小的指令。
css代码:
主要控制样式
<style type="text/css"> *{margin: 0px;padding: 0px;} .slide {width: 200px;height:200px;border:1px solid #dcdcdc;margin: 0 auto;margin-top: 50px;overflow: hidden;} .slide li {height: 49px;line-height: 49px;text-align: left;padding: 0 10px;font-size: 16px;list-style: none;border-bottom: 1px dashed #dcdcdc;cursor: pointer;} .slide li:hover{background: #ccc;} </style>
html代码:
<body ng-app="tip"> <div ng-controller = "tipcontroller"> <div class="slide"> <ul class="slideul"> <!-- 指令 --> <slide-follow id="slide" dataset-data = "datasetdata"></slide-follow> </ul> </div> </div> </body>
当然我们的代码都是基于页面中已经引入angular.js文件下来运行的
slide-follow是我们需要实现的指令 dataset-data = "datasetdata" 是我们需要显示的文字js代码
<script type="text/javascript"> var app =angular.module("tip",[]); app.controller("tipcontroller",function($scope){ // 数据可以根据自己使用情况更换 $scope.datasetdata = [ {option : "这个是第一条数据"}, {option : "这个是第二条数据"}, {option : "这个是第三条数据"}, {option : "这个是第四条数据"}, {option : "这个是第五条数据"}, {option : "这个是第六条数据"} ] }) .directive("slidefollow",function($timeout){ return { restrict : 'e', replace : true, scope : { id : "@", datasetdata : "=" }, template : "<li ng-repeat = 'data in datasetdata'>{{data.option}}</li>", link : function(scope,elem,attrs) { $timeout(function(){ var classname = $("." + $(elem).parent()[0].classname); var i = 0,sh; var lilength = classname.children("li").length; var liheight = classname.children("li").height() + parseint(classname.children("li").css('border-bottom-width')); classname.html(classname.html() + classname.html()); // 开启定时器 sh = setinterval(slide,4000); function slide(){ if (parseint(classname.css("margin-top")) > (-lilength * liheight)) { i++; classname.animate({ margintop : -liheight * i + "px" },"slow"); } else { i = 0; classname.css("margin-top","0px"); } } // 清除定时器 classname.hover(function(){ clearinterval(sh); },function(){ clearinterval(sh); sh = setinterval(slide,4000); }) },0) } } }) </script>
首先我们在controller中定义了需要显示的文字,接下来我们就可以开始定义指令部分。
运行效果图:
文字上下会无缝滚动,当鼠标移入是,会清除定时器,停止滚动。
以上所述是小编给大家介绍的angularjs实现文字上下无缝滚动特效代码,希望对大家有所帮助