当前位置: 移动技术网 > IT编程>脚本编程>AngularJs > angularjs实现文字上下无缝滚动特效代码

angularjs实现文字上下无缝滚动特效代码

2018年05月11日  | 移动技术网IT编程  | 我要评论

最近没有项目做,于是闲暇之余学习了下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实现文字上下无缝滚动特效代码,希望对大家有所帮助

如对本文有疑问, 点击进行留言回复!!

相关文章:

验证码:
移动技术网