通過90行程式碼學會HTML5 WebSQL的4種基本操作
Web SQL資料庫API是一個獨立的規範,在瀏覽器層面提供了本地對結構化資料的儲存,已經被很多現代瀏覽器支援了。
我們通過一個簡單的例子來了解下如何使用Web SQL API在瀏覽器端建立資料庫表並儲存資料。
<!doctype html><html><head> <script> var end; function setupDB() { return this.createDatabase().then(createTable).then(insertEntry).then(readEntry).then(printResult); } function createTable() { return new Promise(function(resovle, reject) { console.log("prepare to create table..." + Date.now()); this._db.transaction(function(query) { query.executeSql('create table if not exists user(id unique, user, passwd)'); }); setTimeout(_createTableOK.bind(this, resovle), 1000); }); } function _createTableOK(resovle) { console.log("table created successfully..." + Date.now()); resovle(); } function createDatabase() { return new Promise(function(resovle, reject) { console.log("prepare to create database..." + Date.now()); this._db = openDatabase('mydb', '1.0', 'JerryTestdb', 1024); setTimeout(_createDatabaseOK.bind(this, resovle), 1000); }); } function _createDatabaseOK(resovle) { console.log("database created successfully..." + Date.now()); resovle(this._db); } function insertEntry() { return new Promise(function(resolve, reject) { this._db.transaction(function(query) { query.executeSql("insert into user values (1,'Jerry','1234')"); }); setTimeout(_insertEntryOK.bind(this, resolve), 1000); }); } function _insertEntryOK(resolve) { console.log("entry inserted to table successfully..." + Date.now()); resolve(); } function readEntry() { return new Promise(function(resolve, reject) { this._db.transaction(function(query) { query.executeSql('select * from user', [], function(u, results) { setTimeout(_readEntryOK.bind(this, resolve, results), 1000); }); // end of query.executeSql } // end of function(query) ); // end of this._db.transaction }); } function _readEntryOK(resolve, oResult) { console.log("entry readed from DB successfully..." + Date.now()); resolve(oResult); } function printResult(oResults) { for (var i = 0; i < oResults.rows.length; i++) { document.writeln('id: ' + oResults.rows[i].id); document.writeln('user: ' + oResults.rows[i].user); document.writeln('passwd: ' + oResults.rows[i].passwd); } end = true; } function work() { if (end) { clearInterval(handle); } else { console.log(" working..." + Date.now()); } } setupDB(); var handle = setInterval(work, 200); </script></head></html>
在瀏覽器裡執行這個應用,會建立一個名叫mydb的資料庫,裡面一張名為“user”的資料庫表,並且插入一條記錄進去,然後從資料庫表中讀取中來,列印在瀏覽器上。
下面就來分析下這90行程式碼。
程式的入口是setupDB這個函式,下面的setInterval起了1個間隔為200毫秒的週期執行函式,為了模擬當前瀏覽器除了進行Web SQL資料庫外,還有其他的任務再執行。
setupDB
用promise實現了一個鏈式呼叫,第九行程式碼從語義上來說很容易理解:首先建立資料庫(createDatabase),然後建立資料庫表(createTable),然後插入一條記錄到資料庫表裡(insertEntry), 然後馬上把剛才插入表裡的記錄讀出來(readEntry)。最後列印到瀏覽器上。
大家看我第16行的_createDatabaseOK的函式延時1秒執行,僅僅是為了演示WebSQL API 非同步呼叫的最佳實踐。
createDatabase函式的第15行,呼叫了Web SQL API的openDatabase,建立了一個名為mydb的資料庫。openDatabase會返回一個資料庫控制程式碼,我們儲存在屬性_db裡以便後續使用。
createTable
使用前一步驟得到的資料庫控制程式碼,通過資料庫控制程式碼暴露的API transaction, 執行一個資料庫事務。事務的具體內容是一個SQL語句,通過executeSql呼叫來建立資料庫表:
create table if not exists user(id unique, user, passwd)
用過JDBC的朋友對這種寫法應該很熟悉。
資料庫表明為user,主鍵為id,有兩個列user和passwd。
insertEntry
在前一步驟中建立的user資料庫表中插入一行記錄,id為1,user值為Jerry,passwd為1234。
insert into user values (1,'Jerry','1234')
readEntry
還是通過第一步建立的資料庫控制程式碼_db, 執行一個資料庫事務,內容為SELECT語句,從user表裡讀出所有記錄。
如果想清除掉Web SQL裡的資料庫表,在Chrome開發者工具裡點選Clear storage:
選中您要清除的Storage型別,點“Clear Site Data"即可。
要獲取更多Jerry的原創技術文章,請關注公眾號"汪子熙"或者掃描下面二維碼:
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/24475491/viewspace-2212343/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- 通過HTTP的HEADER完成各種騷操作HTTPHeader
- sklearn基本操作程式碼練習
- bat指令碼的基本操作BAT指令碼
- ros的幾種通訊機制及程式碼ROS
- GraalVM 21.0提供執行Java程式碼的第三種方式:Espresso通過Truffle框架執行Java程式碼 - graalvmLVMJavaEspresso框架
- MongoDB 4.X CRUD基本操作MongoDB
- 通過 Route 配置的例子,學習SAP Cloud for Customer 的scoping操作Cloud
- 通過shell指令碼批量操作mysql資料庫指令碼MySql資料庫
- 通過程式碼掛上物理頁
- 4、幾種通用防注入程式繞過方法
- 樹狀陣列3種基本操作陣列
- 邦芒職場:職場中學會溝通的基本原則
- JS陣列學習之清空全部元素的4種方法(程式碼詳解)JS陣列
- vim學習筆記——三種基本模式和相關操作筆記模式
- gRPC(2):四種基本通訊模式RPC模式
- 看完這篇Linux基本的操作就會了Linux
- C#程式設計學習(04):基本操作學習總結C#程式設計
- Hive學習之基本操作Hive
- ajax與json通過程式碼的簡單應用JSON
- c# 操作Redis的五種基本型別總結C#Redis型別
- 看完這篇 Linux 的基本操作你就會了!Linux
- 使用chatgt(GPT-4)將過程式(的java程式碼)改成函式式(的elixir程式碼)GPTJava函式
- 幾個騷操作,讓程式碼自動學會畫畫,太好玩啦!
- git各種操作:基本操作 and 多人協作 and 衝突解決Git
- 通過命令curl 操作ElasticSearch指南Elasticsearch
- Oracle 重置密碼及基本操作Oracle密碼
- Python 4 種不同的存取檔案騷操作Python
- 怎麼通過Python掙外快,通過Python掙外快的幾種方式!Python
- Android通過程式碼修改圖片顏色Android
- [轉載] python通過反射執行程式碼Python反射行程
- Go 操作 Redis 的基本操作GoRedis
- 無需複雜的數學描述,通過簡單程式碼理解卷積模組卷積
- 通過原始碼學習@functools.lru_cache原始碼
- Python 通過List 實現佇列的操作Python佇列
- 讀HikariCP原始碼學Java(一)-- 通過ConcurrentBag類學習併發程式設計思想原始碼Java程式設計
- 安卓應用安全指南5.4.1通過HTTPS的通訊示例程式碼安卓HTTP
- 一種通過程式設計面試的演算法 - malisper.me程式設計面試演算法Lisp
- 強化學習的基本概念與程式碼實現強化學習