我正在开发一个类似tinder的应用程序,我成功创建了向左滑动和向右滑动的效果,我在那里使用ng-repeat,但我希望卡片不会重复,直到所有卡片都转换一次。
这是我的代码: -
<html>
<head>
<meta charset="utf-8">
<meta name="viewport" content="initial-scale=1, maximum-scale=1, user-scalable=no, width=device-width">
<title>Tinder Clone</title>
<link href="http://112.196.33.85/solitaire/demoui/john/10oct/css/style.css" rel="stylesheet">
<script src="http://112.196.33.85/solitaire/demoui/john/10oct/js/custom.js"></script>
<script src="http://112.196.33.85/solitaire/demoui/john/10oct/js/cards.js"></script>
<style>
.ionic-logo {
display: block;
margin: 15px auto;
width: 96px;
height: 96px;
}
.pane {
background-color: #333 !important
}
.bar.bar-transparent {
background-color: transparent;
background-image: none;
border: none;
}
.bar .title {
color: #eee;
}
.swipe-cards {
position: fixed;
}
.swipe-card {
-webkit-perspective: 1000;
-moz-perspective: 1000;
-webkit-backface-visibility: hidden;
-moz-backface-visibility: hidden;
display: none;
position: fixed;
-webkit-transform: scale(1,1);
-moz-transform: scale(1,1);
left: 50%;
top: 50%;
width: 300px;
height: 245px;
margin-left: -150px;
margin-top: -150px;
box-sizing: border-box;
background-color: rgb(255,255,255);
border-radius: 4px;
overflow: hidden;
-webkit-animation-fill-mode: forwards;
-moz-animation-fill-mode: forwards;
}
.swipe-card .title {
height: 0px;
/*padding: 5px;*/
line-height: 30px;
color: #444;
}
.swipe-card .image {
overflow: hidden;
max-height: 250px;
}
.swipe-card .button {
border: none;
}
.swipe-card .image img {
width: 100%;
border-radius: 0px 0px 4px 4px; min-height:200px; max-height:200px;
}
#start-card {
color: #fff;
background-color: #30BD8A;
line-height: 300px;
word-wrap: break-word;
border: 6px solid #4CD68E;
text-align: center;
}
#start-card span {
display: inline-block;
line-height: 40px;
width: 200px;
font-size: 30px;
vertical-align: middle;
}
#footer .button {
color: #fff;
}
@-webkit-keyframes bounceIn {
0% {
-webkit-transform: scale(0,0);
}
70% {
-webkit-transform: scale(1.2,1.2);
}
100% {
-webkit-transform: scale(1,1);
}
}
@-moz-keyframes bounceIn {
0% {
-moz-transform: scale(0,0);
}
70% {
-moz-transform: scale(1.2,1.2);
}
100% {
-moz-transform: scale(1,1);
}
}
.swipe-card.pop-in-start {
-webkit-transform: scale(0,0);
-moz-transform: scale(0,0);
}
.swipe-card.pop-in {
-webkit-animation: bounceIn 0.3s ease-out;
-moz-animation: bounceIn 0.3s ease-out;
}
</style>
</head>
<body ng-app="starter" animation="slide-left-right-ios7" no-scroll>
<pane ng-controller="CardsCtrl" class="pane">
<header-bar type="bar-transparent" title="'Help out'"></header-bar>
<p style="color:white; display:none;">Accepted: {{accepted}}, Rejected: {{rejected}}</p>
<swipe-cards>
<swipe-card on-swipe="cardSwiped()" id="start-card">
<img src="images/pic1.jpg" alt=""/>
</swipe-card>
<swipe-card ng-repeat="card in cards" on-swipe="cardSwiped($index)">
<div ng-controller="CardCtrl">
<div class="title">
{{card.title}}
</div>
<div class="image">
<img ng-src="{{card.image}}">
</div>
<div class="button-bar">
<button style="color:red;" class="button button-clear button-positive" ng-click="reject()">UGH</button>
<button style="color:green;" class="button button-clear button-positive" ng-click="accept()">YUM</button>
</div>
</div>
</swipe-card>
</swipe-cards>
</pane>
<script>
angular.module('starter', ['ionic', 'ionic.contrib.ui.cards'])
.directive('noScroll', function($document) {
return {
restrict: 'A',
link: function($scope, $element, $attr) {
$document.on('touchmove', function(e) {
e.preventDefault();
});
}
}
})
.controller('CardsCtrl', function($scope, $ionicSwipeCardDelegate, $rootScope) {
$rootScope.accepted = 0;
$rootScope.rejected = 0;
var cardTypes = [
{ title: '', image: 'images/pic1.jpg' },
{ title: '', image: 'images/pic2.jpg' },
{ title: '', image: 'images/pic3.jpg' },
{ title: '', image: 'images/pic4.jpg' },
{ title: '', image: 'images/pic5.jpg' },
{ title: '', image: 'images/pic6.jpg' },
{ title: '', image: 'images/pic7.jpg' },
{ title: '', image: 'images/pic8.jpg' },
{ title: '', image: 'images/pic9.jpg' },
{ title: '', image: 'images/pic10.jpg' }
];
$scope.cards = Array.prototype.slice.call(cardTypes, 0, 0);
$scope.cardSwiped = function(index) {
$scope.addCard();
};
$scope.cardDestroyed = function(index) {
if (this.swipeCard.positive === true) {
$scope.$root.accepted++;
} else {
$scope.$root.rejected++;
}
$scope.cards.splice(index, 1);
};
$scope.addCard = function() {
var newCard = cardTypes[Math.floor(Math.random() * cardTypes.length)];
newCard.id = Math.random();
$scope.cards.push(angular.extend({}, newCard));
}
})
.controller('CardCtrl', function($scope, $ionicSwipeCardDelegate, $rootScope) {
$scope.accept = function () {
var card = $ionicSwipeCardDelegate.getSwipebleCard($scope);
$rootScope.accepted++;
card.swipe(true);
}
$scope.reject = function() {
var card = $ionicSwipeCardDelegate.getSwipebleCard($scope);
$rootScope.rejected++;
card.swipe();
};
});
</script>
</body>
</html>
答案 0 :(得分:0)
我认为您应该为所有对象添加一个属性,例如swaped
,这样当您只需要执行card.swaped = true;
和ng-repeat过滤器card.swaped == true
<swipe-card ng-repeat="card in cards | filter:swaped:false" on-swipe="cardSwiped($index)">