html5-localStorage本地存储和SQLLite本地数据库

2024-05-16 05:48

本文主要是介绍html5-localStorage本地存储和SQLLite本地数据库,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

localstorage和cookie

cookie缺点:

① cookie大小限制在4k左右,不适合存业务数据

② cookie每次随HTTP事务一起发送,浪费带宽

localstorage优势:

① localstorage大小限制在500万字符左右,各个浏览器不一致

② localstorage在隐私模式下不可读取

③ localstorage本质是在读写文件,数据多的话会比较卡(firefox会一次性将数据导入内存,想想就觉得吓人啊)

④ localstorage不能被爬虫爬取,不要用它完全取代URL传参

localstorage的使用

判断浏览器的支持:

function supports_html5_storage() {  try {  return 'localStorage' in window && window['localStorage'] !== null;  } catch (e) {  return false;  }  
}  
或使用开源的用来侦测用户浏览器对HTML5支持度的工具(例如Modernizr)
if (Modernizr.localstorage) {  // window.localStorage is available!  
} else {  // 浏览器不支持HTML5 storage :(  // 可以考虑使用dojox.storage 或其他方法  
}  

使用例子

localStorage.a = 3;//设置a为"3"
localStorage["a"] = "sfsf";//设置a为"sfsf",覆盖上面的值
localStorage.setItem("b","isaac");//设置b为"isaac"
var a1 = localStorage["a"];//获取a的值
var a2 = localStorage.a;//获取a的值
var b = localStorage.getItem("b");//获取b的值
localStorage.removeItem("c");//清除c的值if (localStorage.pagecount){localStorage.pagecount=Number(localStorage.pagecount) +1;}
else{localStorage.pagecount=1;}
document.write("Visits "+ localStorage.pagecount + " time(s).");
</script>

SQLLite本地数据库

本地数据库支持比较少,不够规范,建议少用

本地数据库是H5之后出现的SQLLite数据库,可以通过SQL语言来访问文件型SQL数据库

使用数据库的步骤:

  1. 创建访问数据库
  2. 使用事务处理

创建访问数据库对象
博客出处
var db= openDatabase(‘mydb’,’1.0’,’TestDB’,2*1024*1024)

第一个参数:数据库名

第二个参数:版本号

第三个参数:数据库描述

第四个参数:数据库大小

该方法返回创建后的数据库访问对象,如果该数据库不存在,则创建数据库

用executeSql执行查询

transaction.executeSql(sqlquery,[],dataHandler,errorHandler);

第一个参数:查询语句

第二个参数:查询语句中的?

eg: transaction.executeSql(“UPDATE people set age=? which name=?”,[age,name])

第三个参数:执行成功时调用的回调函数

function dataHandler(transaction,result){//回调函数内容}

第四个参数:执行失败时调用的回调函数

function errorHandler(transaction,erromsg){//alert(“执行出错!”)}

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><title>Sqlite</title>
</head>
<body onload="init()"><!-- 创建数据库对象、使用事务进行数据库操作 -->姓名:<input type="text" id="name"/>电话:<input type="text" id="tel" /><input type="button" value="保存" onclick="saveData()" /><hr/><input type="button" onclick="showAllData()" value="显示全部"><input type="button" onclick="delAllData()" value="清空全部"><hr/><table id="datatable" border="1"></table><p id="'msg"></p></body>
<script type="text/javascript">var datatable = null;var db = openDatabase('myTel','1.0','test db',1024*100);//数据库名 版本 数据库描述 大小function init(){//初始化工作datatable = document.getElementById('datatable');showAllData();}function removeAllData(){//移除页面上展示的数据for(var i = datatable.childNodes.length-1;i>=0;i--){datatable.removeChild(datatable.childNodes[i]);}var tr = document.createElement('tr');var th1 = document.createElement('th');var th2 = document.createElement('th');th1.innerHTML = '姓名';th2.innerHTML = '电话';tr.appendChild(th1);tr.appendChild(th2);datatable.appendChild(tr);}function showData(row){//显示数据var tr = document.createElement('tr');var td1 = document.createElement('td');td1.innerHTML = row.name;var td2 = document.createElement('td');td2.innerHTML = row.tel;tr.appendChild(td1);tr.appendChild(td2);datatable.appendChild(tr);}function showAllData(){//显示所有数据db.transaction(function (tx){tx.executeSql('create table if not exists TelData(name TEXT,tel TEXT)',[],function(tx,res){},function(tx,err){alert(err.message)});tx.executeSql('select * from TelData',[],function(tx,result){removeAllData();for(var i = 0 ;i<result.rows.length;i++){showData(result.rows.item(i));}})})}function saveData(){//保存数据var name = document.getElementById('name').value;var tel = document.getElementById('tel').value;addData(name,tel);showAllData();}function addData(name,tel){//添加数据db.transaction(function(tx){tx.executeSql('insert into TelData values(?,?)',[name,tel],function(tx,rs){alert('yes');},function (tx,err){alert(err.source +'===='+err.message);})})}function  delAllData(){//删除所有数据db.transaction(function(tx){tx.executeSql('delete from TelData',[],function(tx,res){alert('删除成功~');},function (tx,err){alert('删除失败'+err.message);})})showAllData();}
</script>
</html>

参考
http://blog.csdn.net/sinat_25127047/article/details/51360868
http://www.cnblogs.com/yexiaochai/p/4509472.html
http://blog.csdn.net/dojotoolkit/article/details/6614883
http://html5doctor.com/introducing-web-sql-databases/
https://dev.w3.org/html5/webdatabase/
http://blog.csdn.net/panda_m/article/details/49951555

这篇关于html5-localStorage本地存储和SQLLite本地数据库的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/994043

相关文章

Python实现对阿里云OSS对象存储的操作详解

《Python实现对阿里云OSS对象存储的操作详解》这篇文章主要为大家详细介绍了Python实现对阿里云OSS对象存储的操作相关知识,包括连接,上传,下载,列举等功能,感兴趣的小伙伴可以了解下... 目录一、直接使用代码二、详细使用1. 环境准备2. 初始化配置3. bucket配置创建4. 文件上传到os

MySQL数据库中ENUM的用法是什么详解

《MySQL数据库中ENUM的用法是什么详解》ENUM是一个字符串对象,用于指定一组预定义的值,并可在创建表时使用,下面:本文主要介绍MySQL数据库中ENUM的用法是什么的相关资料,文中通过代码... 目录mysql 中 ENUM 的用法一、ENUM 的定义与语法二、ENUM 的特点三、ENUM 的用法1

一文详解Git中分支本地和远程删除的方法

《一文详解Git中分支本地和远程删除的方法》在使用Git进行版本控制的过程中,我们会创建多个分支来进行不同功能的开发,这就容易涉及到如何正确地删除本地分支和远程分支,下面我们就来看看相关的实现方法吧... 目录技术背景实现步骤删除本地分支删除远程www.chinasem.cn分支同步删除信息到其他机器示例步骤

Java中调用数据库存储过程的示例代码

《Java中调用数据库存储过程的示例代码》本文介绍Java通过JDBC调用数据库存储过程的方法,涵盖参数类型、执行步骤及数据库差异,需注意异常处理与资源管理,以优化性能并实现复杂业务逻辑,感兴趣的朋友... 目录一、存储过程概述二、Java调用存储过程的基本javascript步骤三、Java调用存储过程示

Go语言数据库编程GORM 的基本使用详解

《Go语言数据库编程GORM的基本使用详解》GORM是Go语言流行的ORM框架,封装database/sql,支持自动迁移、关联、事务等,提供CRUD、条件查询、钩子函数、日志等功能,简化数据库操作... 目录一、安装与初始化1. 安装 GORM 及数据库驱动2. 建立数据库连接二、定义模型结构体三、自动迁

MySQL之InnoDB存储引擎中的索引用法及说明

《MySQL之InnoDB存储引擎中的索引用法及说明》:本文主要介绍MySQL之InnoDB存储引擎中的索引用法及说明,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐... 目录1、背景2、准备3、正篇【1】存储用户记录的数据页【2】存储目录项记录的数据页【3】聚簇索引【4】二

MySQL之InnoDB存储页的独立表空间解读

《MySQL之InnoDB存储页的独立表空间解读》:本文主要介绍MySQL之InnoDB存储页的独立表空间,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1、背景2、独立表空间【1】表空间大小【2】区【3】组【4】段【5】区的类型【6】XDES Entry区结构【

SQLite3 在嵌入式C环境中存储音频/视频文件的最优方案

《SQLite3在嵌入式C环境中存储音频/视频文件的最优方案》本文探讨了SQLite3在嵌入式C环境中存储音视频文件的优化方案,推荐采用文件路径存储结合元数据管理,兼顾效率与资源限制,小文件可使用B... 目录SQLite3 在嵌入式C环境中存储音频/视频文件的专业方案一、存储策略选择1. 直接存储 vs

嵌入式数据库SQLite 3配置使用讲解

《嵌入式数据库SQLite3配置使用讲解》本文强调嵌入式项目中SQLite3数据库的重要性,因其零配置、轻量级、跨平台及事务处理特性,可保障数据溯源与责任明确,详细讲解安装配置、基础语法及SQLit... 目录0、惨痛教训1、SQLite3环境配置(1)、下载安装SQLite库(2)、解压下载的文件(3)、

MySQL数据库的内嵌函数和联合查询实例代码

《MySQL数据库的内嵌函数和联合查询实例代码》联合查询是一种将多个查询结果组合在一起的方法,通常使用UNION、UNIONALL、INTERSECT和EXCEPT关键字,下面:本文主要介绍MyS... 目录一.数据库的内嵌函数1.1聚合函数COUNT([DISTINCT] expr)SUM([DISTIN