ホームページ  >  記事  >  ウェブフロントエンド  >  Angularjs はテキストを上下にシームレスにスクロールする特殊効果コードを実現します

Angularjs はテキストを上下にシームレスにスクロールする特殊効果コードを実現します

高洛峰
高洛峰オリジナル
2016-12-29 10:40:331732ブラウズ

最近やるべきプロジェクトがないので、空いた時間で 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 は、実行する必要がある命令ですimplement 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 : &#39;E&#39;,
replace : true,
scope : {
id : "@",
datasetData : "="
},
template : "<li ng-repeat = &#39;data in datasetData&#39;>{{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(&#39;border-bottom-width&#39;));
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>

まず、コントローラーに表示する必要があるテキストを定義し、それから命令部分の定義を開始できます。

レンダリングの実行:

Angularjs はテキストを上下にシームレスにスクロールする特殊効果コードを実現します

マウスが [はい] に移動すると、タイマーがクリアされ、スクロールが停止します。

上記は、シームレスなテキストの上下スクロールを実現するためにエディターが紹介する angularjs コードです。ご質問があれば、メッセージを残してください。エディターが返信します。間に合ったあなた。また、PHP 中国語 Web サイトをサポートしていただきありがとうございます。

テキストの上下のシームレスなスクロール特殊効果コードの angularjs 実装の詳細については、PHP 中国語 Web サイトに注目してください。


声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。