ホームページ > 記事 > ウェブフロントエンド > Angularjs はテキストを上下にシームレスにスクロールする特殊効果コードを実現します
最近やるべきプロジェクトがないので、空いた時間で 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 : '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>
まず、コントローラーに表示する必要があるテキストを定義し、それから命令部分の定義を開始できます。
レンダリングの実行:
マウスが [はい] に移動すると、タイマーがクリアされ、スクロールが停止します。
上記は、シームレスなテキストの上下スクロールを実現するためにエディターが紹介する angularjs コードです。ご質問があれば、メッセージを残してください。エディターが返信します。間に合ったあなた。また、PHP 中国語 Web サイトをサポートしていただきありがとうございます。
テキストの上下のシームレスなスクロール特殊効果コードの angularjs 実装の詳細については、PHP 中国語 Web サイトに注目してください。