indexeddb
2021.02.07 20:03
로메오의 블로그 :: [Chrome] IndexedDB 사용하기 (tistory.com)
아래는 전체 코드입니다.
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<meta http-equiv="X-UA-Compatible" content="ie=edge">
<title>IndexedDB</title>
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.4.1/jquery.min.js"></script>
</head>
<body>
companyName: <input type="text" id="companyName"><br>
production: <input type="text" id="production"><br>
<button id="submit">입력</button>
<button id="clearAll">모두삭제</button>
<ul id="lists"></ul>
<script>
const DATABASE = 'MyDatabase';
const DB_VERSION = 1;
const DB_STORE_NAME = 'company';
var db;
openDB = () => {
// DB 생성
var req = indexedDB.open(DATABASE, DB_VERSION);
// DB 생성 성공
req.onsuccess = function (evt) {
db = this.result;
getAllData();
};
// DB 생성 오류
req.onerror = function (evt) {
console.error("indexedDB : ", evt.target.errorCode);
};
// DB 마그레이션
req.onupgradeneeded = function (evt) {
console.log("indexedDB.onupgradeneeded");
var store = evt.currentTarget.result.createObjectStore(DB_STORE_NAME,
{ keyPath: 'id', autoIncrement: true });
store.createIndex('company', 'company', { unique: true });
store.createIndex('production', 'production', { unique: false });
};
}
openDB()
// Store를 반환한다.
getObjectStore = (store_name, mode) => {
return db.transaction(store_name, mode).objectStore(store_name);
}
// 데이터 입력하기
$('#submit').on('click', () => {
const companyName = $('#companyName').val()
const production = $('#production').val()
if (!companyName) {
return alert('company name은 필수입니다.')
}
if (!production) {
return alert('production은 필수입니다.')
}
// 입력한 데이터를 추가한다.
let store = getObjectStore(DB_STORE_NAME, 'readwrite');
let req
const obj = {
company: companyName,
production: production
};
try {
req = store.add(obj);
} catch (e) { }
req.onsuccess = function (evt) {
console.log("입력 되었습니다.");
};
req.onerror = function () {
console.error(this.error);
};
})
// 모든 데이터를 가지고 온다.
getAllData = () => {
// get
store = getObjectStore(DB_STORE_NAME, 'readonly');
let req = store.openCursor();
let strBuffer = []
req.onsuccess = evt => {
const cursor = evt.target.result;
if (cursor) {
req = store.get(cursor.key);
req.onsuccess = function (evt) {
const value = evt.target.result;
strBuffer.push('<li>')
strBuffer.push(value.company + ' (' + value.production + ')')
strBuffer.push(' [<a href="#" data-delete="' + value.id + '">삭제</a>]')
strBuffer.push('</li>')
console.log(value)
}
cursor.continue();
}
$('#lists').html(strBuffer.join(''))
// 데이터를 삭제한다.
$('[data-delete]').on('click', evt => {
const id = $(evt.currentTarget).attr('data-delete')
store = getObjectStore(DB_STORE_NAME, 'readwrite');
store.delete(id)
.onsuccess = event => {
console.log('deleted')
}
})
}
}
// 데이터를 모두 삭제한다.
$('#clearAll').on('click', () => {
// clear
var store = getObjectStore(DB_STORE_NAME, 'readwrite');
var req = store.clear();
req.onsuccess = function (evt) {
console.log('clear')
};
req.onerror = function (evt) {
console.log('error')
};
})
</script>
</body>
</html>
번호 | 제목 | 글쓴이 | 날짜 | 조회 수 |
---|---|---|---|---|
1714 | 방문인사^^ | 하리니 | 2000.09.05 | 2714 |
1713 | -_-+ | ㅡ0ㅡ | 2000.09.05 | 2841 |
1712 | 요맨 | 석원 | 2000.09.06 | 2829 |
1711 | 새 출 발 | 한승석 | 2000.09.08 | 2579 |
1710 | 으 승석아~~ | 재호 | 2000.09.08 | 2752 |
1709 | 잘 쉬어 | 석원 | 2000.09.09 | 2605 |
1708 | 승석이가 천리안에 가입하였습니다. | 한승석 | 2000.09.09 | 2695 |
1707 | 날씨가 서늘해져 가고 있습니다. | 한승석 | 2000.09.09 | 2626 |
1706 | 맘 상하지 말구.. | 혜진누나 | 2000.09.09 | 2649 |
1705 | 승석 생각 -별- | 한승석 | 2000.09.14 | 2517 |
1704 | 부탁한 일!!! | 혜진누나 | 2000.09.14 | 2461 |
1703 | Re: 부탁한 일!!! | 한승석 | 2000.09.14 | 2771 |
1702 | Re: 승석 생각 -별- | Ryan | 2000.09.17 | 2281 |
1701 | Re: 승석 생각 -별- | 한승석 | 2000.09.18 | 2490 |
1700 | .....어떻게 내가 들어 왔지? | 문지나 | 2000.09.18 | 2610 |
Storage - Apache Cordova