9
我正在努力解决一个问题:我有一个包含x项数量的菜单。 在这个例子中,我有三个项目。ngAnimate - 双向滑动
每个项目都有一个内容部分,所以通过点击菜单项,内容应滑动。
到目前为止,我所取得的成就,就是当你从“项目1”,并开始改变到“项目2”将做动画(从右向左滑动,如幻灯片幻灯片)
但是我想要反向效果,所以它会从右向左滑动从“项目2 “到”项目1“。 我只是无法弄清楚如何在两种方式下做到这一点。
所以我要求的是ngAnimate的某种旋转木马,所以我不必为这些动画返回jQuery。我想在使用AngularJS时从我的项目中删除jQuery。
console.clear();
var _app = angular.module("animate", ['ngAnimate']);
_app.directive("animate", [function() {
return {
scope: {},
template: '<div class="header">' +
' \t \t <ul>' +
' \t \t \t <li data-ng-repeat="item in items" data-ng-click="move($index)">' +
' \t \t \t \t <div>{{item}}</div>' +
' \t \t \t </li>' +
' \t \t </ul>' +
'</div>' +
'<div class="wrapper" style="position: relative; margin-top: 20px;">' +
' \t \t <div data-ng-if="index == 0" class="slide slide-left">Content 1</div>' +
' \t \t <div data-ng-if="index == 1" class="slide slide-left">Content 2</div>' +
' \t \t <div data-ng-if="index == 2" class="slide slide-left">Content 3</div>' +
'</div>',
link: function(scope, elem, attr) {
scope.items = ["Item 1", "Item 2", "Item 3"]
scope.index = 0;
scope.move = function(index) {
scope.index = index;
}
}
}
}]);
body {
font-family: Arial, Sans-Serif;
}
.header {
width: 100%;
height: 50px;
background-color: lightblue;
position: relative;
}
.header ul {
padding: 0;
height: inherit;
}
.header ul li {
display: inline;
width: 33%;
height: inherit;
}
.header ul li div {
float: left;
width: 33%;
text-align: center;
height: inherit;
border: 1px solid black;
}
.slide {
-webkit-transition: all cubic-bezier(0.250, 0.460, 0.450, 0.940) 2s;
-moz-transition: all cubic-bezier(0.250, 0.460, 0.450, 0.940) 2s;
-o-transition: all cubic-bezier(0.250, 0.460, 0.450, 0.940) 2s;
transition: all cubic-bezier(0.250, 0.460, 0.450, 0.940) 2s;
position: absolute;
}
.slide-left.ng-enter {
left: 100%;
}
.slide-left.ng-enter.ng-enter-active {
left: 0;
}
.slide-left.ng-leave {
left: 0;
}
.slide-left.ng-leave.ng-leave-active {
left: -100%;
}
.slide-right.ng-enter {
left: -100%;
}
.slide-right.ng-enter.ng-enter-active {
left: 0
}
.slide-right.ng-leave {
left: 0;
}
.slide-right.ng-leave.ng-leave-active {
left: 100%;
}
<script src="http://cdnjs.cloudflare.com/ajax/libs/angular.js/1.4.8/angular.js"></script>
<script src="https://code.angularjs.org/1.4.8/angular-animate.js"></script>
<div ng-app="animate">
<animate></animate>
</div>
不符合我的预期:从内容1滑动到内容2从左到右并不是真正的旋转木马会做什么。但我很欣赏这个答案,当我得到时间时,我会看看UI Bootstrap :) – Jorrex
@Jorrex请看看编辑后的答案,我想现在它可以按照你想要的方式工作。 –
是的!这就是我想要的。非常感谢你,我无法弄清楚,并且陷入了这么长时间。现在阅读你的代码,看起来很简单.. – Jorrex