向左/向右滑动用户媒体卡以显示下一个

时间:2016-04-28 07:19:44

标签: javascript html css angularjs

我正在尝试实现一个ng-repeats用户媒体水平对象的小部件,我应该能够向左/向右滑动以显示下一张媒体卡。小部件应该看起来像这样

正如您所见,

下一张卡片头像是半可见的,暗示有更多卡片可以刷卡。

这就是我目前所有的......我被困在这里

div class="media  people-card-media col-xs-12" ng-repeat="item in cats">
        <div class="media-left ">
            <div class="person-photo presence" >
                <img  class="media-object list__photo img-circle" ng-src="{{item.photo}}" />

            </div>
        </div>
        <div class="media-body list__body">
            <div class="people_name_title">
                <h4 class="media-heading title">{{item.name}}</h4>

            </div>
        </div>
        <div class="media-right media-middle contacts-chat-call flex-it-align-top">
            <a  style="margin-right: 10px;">
               call
            </a>

        </div>
    </div>

继承人http://plnkr.co/edit/YESgpGIXQrK9sYl79FVI?p=preview

1 个答案:

答案 0 :(得分:2)

这是一个带有工作实现的plunkr。

http://plnkr.co/edit/wmIyCFM57hniZQ82Z8Ba?p=preview

我在HTML中添加了ngTouch ng-class和触摸事件处理程序。

  <div class="media people-card-media col-xs-12" 
       ng-class="item.displayClass"
       ng-repeat="item in heroes"
       ng-click="gonext()"
       ng-swipe-left="gonext()"
       ng-swipe-right="goprev()">

在MainController中,它通过为其分配current类以及向邻居分配next-upprevious类来翻转活动项目。

$scope.gonext = function () {
  for (var i=0, len=$scope.heroes.length; i<len; i++) {
    if ($scope.heroes[i].displayClass == 'current') {
      $scope.heroes[i].displayClass = 'previous';
      if (i<len-1) $scope.heroes[i+1].displayClass = 'current';
      if (i<len-2) $scope.heroes[i+2].displayClass = 'next-up';
      i=len;
    };
  };
};

只需要更好地处理边界。