gpt4 book ai didi

javascript - Angular.js 动态时间过滤器

转载 作者:行者123 更新时间:2023-11-29 13:05:45 25 4
gpt4 key购买 nike

我有名为 events 的 MySQL 表:

id|  descr  |  time_from |  time_to |
1 | wake up | 10:00:00 | 10:15:00 |
2 | play | 11:00:00 | 12:00:00 |
3 | walk | 14:00:00 | 14:30:00 |

我使用 ng-repeat 循环遍历此表,并尝试应用自己的过滤器,该过滤器应该按当前时间过滤事件。正如您所猜测的,使用此过滤器只应显示一个事件。下面您可以看到我尝试做的事情。

这就是我选择事件并为 Angular 准备 json 的方式:

<?
mysql_connect("localhost","root","");
mysql_select_db('organaizer');
$sql = mysql_query('SELECT * FROM events');
while($lesson = mysql_fetch_array($sql))
{
$rows[] = $lesson;
}
print json_encode($rows);
?>

事件显示良好,没有错误。 Angular 代码:

function eventsCtrl($scope, $http)
{
$http({method: 'POST', url: 'events.php'}).success(function(data)
{
$scope.events = data; // response data
});
$scope.currentTime = function(lesson)
{
//Filter by current time
}
}

标记:

<div class='well' style='margin:10px;' ng-app ng-controller="eventsCtrl">
<div class="table-responsive">
<table class="table table-bordered">
<tr>
<th>#</th>
<th>Event</th>
<th>Start at</th>
<th>End at</th>
</tr>
<tr ng-repeat="event in events | filter:currentTime">
<td>{{event.id}}</td>
<td>{{event.descr}}</td>
<td>{{event.time_from}}</td>
<td>{{event.time_to}}</td>
</tr>
</table>
</div>

因此,我尝试使用 $interval 的示例来应用过滤器在 angularjs.org 上使用时间格式 "HH:mm:ss" ,但不幸的是这没有帮助。也许您有更好的想法如何做到这一点。

最佳答案

我在您提到的示例中使用了“my-current-time”指令 $interval .

我很确定可能有更好的解决方案,但这可行。

请引用代码内的注释

HTML:

<body ng-app="Ang" ng-cloak>
<div class='well' style='margin:10px;' ng-controller="eventsCtrl">
<input type="text" my-current-time="format">
<div class="table-responsive">
<table class="table table-bordered">
<tr>
<th>#</th>
<th>Event</th>
<th>Start at</th>
<th>End at</th>
</tr>
<tr ng-repeat="event in events | filter:currentTime"> <!-- here we're filtering using time_from as 10:00:00 -->
<td>{{event.id}}</td>
<td>{{event.descr}}</td>
<td>{{event.time_from}}</td>
<td>{{event.time_to}}</td>
</tr>
</table>
</div>
</div>
</body>

Javascript

var app = angular.module('Ang', [])
.controller('eventsCtrl', eventsCtrl)
.directive('myCurrentTime', function($interval, dateFilter) {
// return the directive link function. (compile function not needed)
return function(scope, element, attrs) {
var format, // date format
stopTime; // so that we can cancel the time updates

// used to update the UI
function updateTime() {
element.val(dateFilter(new Date(), format));
scope.time = element.val();
}

// watch the expression, and update the UI on change.
scope.$watch(attrs.myCurrentTime, function(value) {
format = value;
updateTime();
});

stopTime = $interval(updateTime, 1000);

// listen on DOM destroy (removal) event, and cancel the next UI update
// to prevent updating time ofter the DOM element was removed.
element.bind('$destroy', function() {
$interval.cancel(stopTime);
});
}
});

function eventsCtrl($scope, $http, dateFilter)
{
$http({method: 'GET', url: 'events.php'}).success(
function(data)
{
$scope.events = data; // response data
}
);
$scope.currentTime = function(lesson)
{
return ($scope.time >= lesson.time_from && $scope.time <= lesson.time_to)
};

$scope.format = 'h:mm:ss';
$scope.time = dateFilter(new Date(), $scope.format);

}

还有 PHP:

<?php

mysql_connect("localhost","root","");
mysql_select_db('organaizer');
$sql = mysql_query('SELECT * FROM events');

while($lesson = mysql_fetch_object($sql)) // Using mysql_fetch_object() function here is better when trying to convert it to JSON ( without adding extra key:value pairs to the data as in mysql_fetch_array() function)
{
$rows[] = $lesson;
}
echo json_encode($rows);

?>

希望这能有所帮助

关于javascript - Angular.js 动态时间过滤器,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/22730772/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com