angular.js 이용

Posted 2013. 11. 18. 10:32

http://angularjs.org/


여기에서 js 를 다운받거나 cdn 주소를 이용.


클라이언트에서 처리하는 언어. 서버가 필요할 때는 ajax 요청.

SPA.

MVC 모델





angular.js 로 todo 리스트 코딩.



index.html

<!doctype html>

<html ng-app>

<head>

<meta charset="utf-8">

<script src="https://ajax.googleapis.com/ajax/libs/angularjs/1.2.1/angular.min.js"></script>

<link rel="stylesheet" href="todo.css">

<script type="text/javascript" src="todo.js"></script>

</head>


<body>

<h2>할일</h2>

<div ng-controller="TodoCtrl">

<span>{{todos.length}} 중 {{remaining()}} 남음!!</span>

[ <a href="" ng-click="archive()">정리</a> ]

<ul>

<li ng-repeat="todo in todos">

<input type="checkbox" ng-model="todo.done">

<span class="done-{{todo.done}}">{{todo.text}}</span>

</li>

</ul>

<form ng-submit="addTodo()">

<input type="text" ng-model="todoText" size="30" placeholder="추가할 할일을 입력하세요">

<input type="submit" value="등록">

</form>

</div>

</body>

</html>



todo.js

function TodoCtrl($scope){

$scope.todos = [

{text:'angular.js 공부', done:true},

{text:'angular.js 앱 만들기', done:false},

];


$scope.remaining = function() {

var count = 0;

angular.forEach($scope.todos, function(todo){

count += todo.done ? 0 : 1;

});

return count;

};


$scope.addTodo = function() {

$scope.todos.push({text:$scope.todoText, done:false});

$scope.todoText = '';

};


$scope.archive = function() {

var oldTodos = $scope.todos;

$scope.todos = [];

angular.forEach(oldTodos, function(todo) {

if(!todo.done) {

$scope.todos.push(todo);

}

})

};


}



todo.css

.done-true {

text-decoration: line-through;

color: lightgray;

}


nodepdf 모듈.


1. phantomjs 를 다운받아 압축풀고 path 를 잡아준다.

2. app.js 의 dependencies 에 'nodepdf' : '*' 을 추가

3. index.js 에


exports.pdfcreate = function(req, res) {

var nodePDF = require('nodepdf');

var path = require('path');

var destpath = path.resove(__dirname, '..', 'uploadfolder', 'naver.pdf'); //

var pdf = new nodePDF('http://www.naver.com', destpath, {width:1024,height:760}) // 캡쳐할 사이트, 저장할 폴더 주소


pdf.on('error', function(msg) {

console.log('error', msg);

});

pdf.on('done', function(pathToFile) {

console.log('pathToFile : ', pathToFile);

res.json({result:'success'});

});


}




클라우르에 올리려면

app.js 에 추가


app.use('/uploads', express.directory(path.join(__dirname, 'uploads')));

app.use('/uploads', express.static(path.join(__dirname, 'uploads')));






www.imagemagick.org/


이런 프로그램이 미리 깔려 있어야 함.


var easyimage = require('easyimage');


var srcimg = 'ree.jpg';


easyimage.info(srcimg, function(err, stdout, stderr){

if(err) console.log("err : ",err);

console.log(stdout);

});


easyimage.resize({src:srcimg, dst:'ree-250x150.jpg', width:250, height:150},

function(err, img){

if(err) console.log("resize err : ", err);

console.log(img);

});


모듈 받으면 test.js 파일이 있는데 그걸 참고하면 됨




node.js async 모듈

Posted 2013. 10. 31. 10:05

비동기 처리 모듈.


npm install async


var async = require('async');


// 순차 처리 series

async.series([

function(callback){

// 처리1

callback(null, 'one');

},

function(callback){

// 처리2

callback(null, 'two');

}],

// 확인하는 처리

function(err, results){

console.log('results', results);

}

);



// 병렬 처리 parallel

async.parallel([

function(callback){

setTimeout(function(){

console.log('하나');

callback(null, '하나');

}, 200);

},

function(callback){

setTimeout(function(){

console.log('둘');

callback(null, '둘');

}, 100);

}],

function(err, results){

console.log('results : ', results);

}

);



npm install cron 하여 설치 후.



var cronJob = require('cron').CronJob;


//초 분 시 일 월 요일

new cronJob('1 8 * * * *', function(){

// 수행하고 싶은 일

console.log('cron execute!');

}, null, true);



별표한 부분에 원하는 시간을 넣으면 매 그 시간마다 동작.


cron API : https://npmjs.org/package/cron






이희승님 블로그

Posted 2013. 10. 15. 12:29

http://t.motd.kr/ko/


첫눈. 네티 개발자 이희승님.

코세라? 코스라?

Posted 2013. 10. 15. 12:22

https://www.coursera.org/


전 세계 유명대학의 강의가 공짜로!!





mysql 에 접속하질 못하는 에러인데

아무래도 root 비밀번호가 문제여서 생기는 듯.


cmd창에 mysqld --skip-grant

입력해 비밀번호 초기화 시키고 실행하면 된다.





qr코드 리더 구현 소스

Posted 2013. 10. 14. 16:33

http://theeye.pe.kr/entry/QR%EC%BD%94%EB%93%9C%EB%A6%AC%EB%8D%94-ZXing%EC%9D%84-%EC%9D%B4%EC%9A%A9%ED%95%98%EC%97%AC-%EB%82%B4-%EC%95%88%EB%93%9C%EB%A1%9C%EC%9D%B4%EB%93%9C-%EC%96%B4%ED%94%8C%EC%97%90-QR%EC%BD%94%EB%93%9C-%EC%8A%A4%EC%BA%90%EB%84%88-%EB%8F%84%EC%9E%85%ED%95%98%EA%B8%B0



http://sunsideup.tistory.com/84



http://androidpomi.blogspot.kr/2011/03/android-zxing-qr.html



http://www.androidside.com/plugin/mobile/board.php?bo_table=B49&wr_id=109770

maven - ArtifactDescriptorException 오류

Posted 2013. 10. 12. 12:46



window - preferences - maven - user setting 에서


update setting 을 누르면 다시 파일을 받으면서 오류 해결.