강좌 & 팁
글 수 2,412
2014.12.23 10:51:17 (*.134.169.166)
73429
02. Controller : http://forum.falinux.com/zbxe/index.php?document_srl=804950
03. controller 사이의 데이터 공유 : http://forum.falinux.com/zbxe/index.php?document_srl=805325
04. controller에 메소드 만들기 : http://forum.falinux.com/zbxe/index.php?document_srl=805915
지난 시간에는 filter의 사용법에 대해서 알아보았습니다.
이번에는 angular-js를 사용하면서 매우 많이 사용하게 되는 ng-repeat에 대해서 알아보겠습니다.
우선 service와 controller를 하나 만들어보겠습니다.
public/javascripts/main.js를 아래와 같이 수정합니다.
var firstApp = angular.module('FirstApp', []);
firstApp.factory('Data', function() {
return {message: "I'm data from a service"}
});
firstApp.factory('Sites', function() {
var Sites = {};
Sites.searchEngines = [
{
name: 'google',
url: 'http://www.google.co.kr'
},
{
name: 'yahoo',
url: 'http://www.yahoo.co.kr'
},
{
name: 'naver',
url: 'http://www.naver.com'
},
{
name: 'daum',
url: 'http://www.daum.net'
},
{
name: 'bing',
url: 'http://www.bing.com'
}
];
return Sites;
});
firstApp.filter('reverse', function() {
return function (text) {
return text.split("").reverse().join("");
}
});
firstApp.controller('FirstCtrl', function($scope, Data) {
$scope.data = Data;
});
firstApp.controller('SecondCtrl', function($scope, Data) {
$scope.data = Data;
$scope.reversedMessage = function (message) {
return message.split("").reverse().join("");
};
});
firstApp.controller('SiteCtrl', function($scope, Sites) {
$scope.sites = Sites;
});
이제 public/index.html을 아래와 같이 수정합니다.
<!DOCTYPE html>
<html>
<head>
<title>Binding</title>
</head>
<body>
<div ng-app="FirstApp">
<div ng-controller="SiteCtrl">
<table>
<tr ng-repeat="site in sites.searchEngines">
<td>{{site.name}}</td>
<td><a href={{site.url}}>{{site.url}}</a></td>
</tr>
</table>
</div>
</div>
<script type="text/javascript" src="components/angularjs/angular.js"></script>
<script type="text/javascript" src="javascripts/main.js"></script>
</body>
</html>
브라우저를 열어서 확인해보면 service에 등록되어있는 검색엔진들이 화면에 출력이 됩니다.
이제 angular-js에 내장되어있는 기본 filter를 사용하여 검색을 할 수 있도록 해보겠습니다.
public/index.html을 아래와 같이 수정합니다.
<!DOCTYPE html>
<html>
<head>
<title>Binding</title>
</head>
<body>
<div ng-app="FirstApp">
<div ng-controller="SiteCtrl">
<input type='text' ng-model='searchText'>
<table>
<tr ng-repeat="site in sites.searchEngines | filter:searchText">
<td>{{site.name}}</td>
<td><a href={{site.url}}>{{site.url}}</a></td>
</tr>
</table>
</div>
</div>
<script type="text/javascript" src="components/angularjs/angular.js"></script>
<script type="text/javascript" src="javascripts/main.js"></script>
</body>
</html>
브라우저를 열어서 확인해보면 텍스트 입력창에 해당하는 글자가 있는 항목만 목록에 나오는 것을 확인할 수 있습니다.
이렇게 filter와 ng-repeat를 사용하면 아주 간단하게 실시간으로 반영이 되는 검색을 만들 수 있습니다.


