안드로이드 아이폰 두 벌 만드느니,
차라리 웹 하나로 만들자
차라리 웹 하나로 만들자
뜬구름 잡는 소린줄 알았는데,
이번에 application cache 보면서
html5가 새삼 다르게 보이는게
이번에 application cache 보면서
html5가 새삼 다르게 보이는게
webos기반에서
html5로 만드는 앱이
나오긴 나올것 같다.
html5로 만드는 앱이
나오긴 나올것 같다.
암튼지간에,
application cache 쓰는법을 설명하자면.
application cache 쓰는법을 설명하자면.
1. manifest 파일을 하나 생성
2. 현재 html에서 참조하는, 캐싱이 필요한 js,css 목록들을 적어준다.
3. manifest 파일을 html에서 include 한다.
2. 현재 html에서 참조하는, 캐싱이 필요한 js,css 목록들을 적어준다.
3. manifest 파일을 html에서 include 한다.
끝. 간단하다.
이렇게만 하면,
이렇게만 하면,
페이지에 처음 한번 접속한 이후부터는
오프라인 상태에서도 실행 할 수 있다.
오프라인 상태에서도 실행 할 수 있다.
manifest 파일
- 방금말한대로 캐싱할 파일들 목록을 적어주는 곳
- 'CACHE MANIFEST' 라는 문구로 시작
- 캐싱방법
. CACHE : 캐쉬할 파일 (문구 표기 생략가능)
. NETWORK : 캐싱하면 안되는 파일 온라인 상태에서만 가능한
. FALLBACK : 캐싱실패 했을때 대체 파일 (ex: A B - A가 없으면 B 호출)
. NETWORK : 캐싱하면 안되는 파일 온라인 상태에서만 가능한
. FALLBACK : 캐싱실패 했을때 대체 파일 (ex: A B - A가 없으면 B 호출)
- 아직은 용량이 5MB 밖에 안됨.
- 주석표시는 '#' 으로
ex) cache.manifest
CACHE MANIFEST
#v 1.0001
CACHE:
css/jquery.mobile-1.0a2.min.css
css/test.css
js/jquery.mobile-1.0a2.min.js
js/jquery-1.7.1.js
NETWORK:
test.jsp
FALLBACK:
A B
ex) test.jsp
<! DOCTYPE html> < html manifest ="cache.manifest" > ..... </html>
cache 업데이트
- 일단 기본적으로 mafnifest 내용이 수정되야만 앱캐쉬가 변경됨.
- 즉 manifest에 들어있는 a.png라는 이미지가 변경되었지만 파일변경 그대로 a.png 라면 앱캐쉬는 예전 내용만 보여줌.
- 그래서 주석으로 버전명 표기하는식으로 많이 사용
cache 상태
- 상태값 = window.applicationCache.satus
- UNCACHED = 캐쉬초기화전(maifest 비교전)
- IDLE = 더 이상 다운로드 할게 없음
- CHECKING = 업데이트 준비 (manifest 비교중)
- DOWNLOADING - 캐시 다운로드중
- UPDATEREADY = 새버전으로 업데이트완료
- OBSOLETE = manifest 파일 못 찾음. 캐쉬삭제.
cache 함수
- update() : manifest 파일 비교
- swapCache() : 캐쉬교체 (캐쉬상태가 updateready 일때 가능)
applicaion cache 관련 블로그
http://www.html5rocks.com/en/tutorials/appcache/beginner/
http://xguru.net/621
댓글
댓글 쓰기