● HTML5本地存储在Android中的应用

HTML5提供了2种客户端存储数据新方法

localStorage 没有时间限制

sessionStorage 针对一个Session的数据存储

Js代码
  1. <scripttype="text/javascript">
  2. localStorage.lastname="Smith";
  3. document.write(localStorage.lastname);
  4. </script>
  5. <scripttype="text/javascript">
  6. sessionStorage.lastname="Smith";
  7. document.write(sessionStorage.lastname);
  8. </script>

WebStorage的API:

Js代码
  1. //清空storage
  2. localStorage.clear();
  3. //设置一个键值
  4. localStorage.setItem(“yarin”,“yangfegnsheng”);
  5. //获取一个键值
  6. localStorage.getItem(“yarin”);
  7. //获取指定下标的键的名称(如同Array)
  8. localStorage.key(0);
  9. //return“fresh”//删除一个键值
  10. localStorage.removeItem(“yarin”);
  11. 注意一定要在设置中开启哦
  12. setDomStorageEnabled(true

Android中进行操作

Java代码
  1. //启用数据库
  2. webSettings.setDatabaseEnabled(true);
  3. Stringdir=this.getApplicationContext().getDir("database",Context.MODE_PRIVATE).getPath();
  4. //设置数据库路径
  5. webSettings.setDatabasePath(dir);
  6. //使用localStorage则必须打开
  7. webSettings.setDomStorageEnabled(true);
  8. //扩充数据库的容量(在WebChromeClinet中实现)
  9. publicvoidonExceededDatabaseQuota(Stringurl,StringdatabaseIdentifier,longcurrentQuota,
  10. longestimatedSize,longtotalUsedQuota,WebStorage.QuotaUpdaterquotaUpdater){
  11. quotaUpdater.updateQuota(estimatedSize*2);
  12. }

JS中按常规进行数据库操作

Js代码
  1. functioninitDatabase(){
  2. try{
  3. if(!window.openDatabase){
  4. alert('Databasesarenotsupportedbyyourbrowser');
  5. }else{
  6. varshortName='YARINDB';
  7. varversion='1.0';
  8. vardisplayName='yarindb';
  9. varmaxSize=100000;//inbytes
  10. YARINDB=openDatabase(shortName,version,displayName,maxSize);
  11. createTables();
  12. selectAll();
  13. }
  14. }catch(e){
  15. if(e==2){
  16. //Versionmismatch.
  17. console.log("Invaliddatabaseversion.");
  18. }else{
  19. console.log("Unknownerror"+e+".");
  20. }
  21. return;
  22. }
  23. }
  24. functioncreateTables(){
  25. YARINDB.transaction(
  26. function(transaction){
  27. transaction.executeSql('CREATETABLEIFNOTEXISTSyarin(idINTEGERNOTNULLPRIMARYKEY,nameTEXTNOTNULL,descTEXTNOTNULL);',[],nullDataHandler,errorHandler);
  28. }
  29. );
  30. insertData();
  31. }
  32. functioninsertData(){
  33. YARINDB.transaction(
  34. function(transaction){
  35. //Starterdatawhenpageisinitialized
  36. vardata=['1','yarinyang','Iamyarin'];
  37. transaction.executeSql("INSERTINTOyarin(id,name,desc)VALUES(?,?,?)",[data[0],data[1],data[2]]);
  38. }
  39. );
  40. }
  41. functionerrorHandler(transaction,error){
  42. if(error.code==1){
  43. //DBTablealreadyexists
  44. }else{
  45. //Errorisahuman-readablestring.
  46. console.log('Oops.Errorwas'+error.message+'(Code'+error.code+')');
  47. }
  48. returnfalse;
  49. }
  50. functionnullDataHandler(){
  51. console.log("SQLQuerySucceeded");
  52. }
  53. functionselectAll(){
  54. YARINDB.transaction(
  55. function(transaction){
  56. transaction.executeSql("SELECT*FROMyarin;",[],dataSelectHandler,errorHandler);
  57. }
  58. );
  59. }
  60. functiondataSelectHandler(transaction,results){
  61. //Handletheresults
  62. for(vari=0;i<results.rows.length;i++){
  63. varrow=results.rows.item(i);
  64. varnewFeature=newObject();
  65. newFeature.name=row['name'];
  66. newFeature.decs=row['desc'];
  67. document.getElementById("name").innerHTML="name:"+newFeature.name;
  68. document.getElementById("desc").innerHTML="desc:"+newFeature.decs;
  69. }
  70. }
  71. functionupdateData(){
  72. YARINDB.transaction(
  73. function(transaction){
  74. vardata=['fengshengyang','Iamfengsheng'];
  75. transaction.executeSql("UPDATEyarinSETname=?,desc=?WHEREid=1",[data[0],data[1]]);
  76. }
  77. );
  78. selectAll();
  79. }
  80. functionddeleteTables(){
  81. YARINDB.transaction(
  82. function(transaction){
  83. transaction.executeSql("DROPTABLEyarin;",[],nullDataHandler,errorHandler);
  84. }
  85. );
  86. console.log("Table'page_settings'hasbeendropped.");
  87. }
  88. 注意onLoad中的初始化工作
  89. functioninitLocalStorage(){
  90. if(window.localStorage){
  91. textarea.addEventListener("keyup",function(){
  92. window.localStorage["value"]=this.value;
  93. window.localStorage["time"]=newDate().getTime();
  94. },false);
  95. }else{
  96. alert("LocalStoragearenotsupportedinthisbrowser.");
  97. }
  98. }
  99. window.onload=function(){
  100. initDatabase();
  101. initLocalStorage();
  102. }

● HTML5地理位置服务在Android中的应用

Android中

Java代码
  1. //启用地理定位
  2. webSettings.setGeolocationEnabled(true);
  3. //设置定位的数据库路径
  4. webSettings.setGeolocationDatabasePath(dir);
  5. //配置权限(同样在WebChromeClient中实现)
  6. publicvoidonGeolocationPermissionsShowPrompt(Stringorigin,
  7. GeolocationPermissions.Callbackcallback){
  8. callback.invoke(origin,true,false);
  9. super.onGeolocationPermissionsShowPrompt(origin,callback);
  10. }

在Manifest中添加权限

Xml代码
  1. <uses-permissionandroid:name="android.permission.ACCESS_FINE_LOCATION"/>
  2. <uses-permissionandroid:name="android.permission.ACCESS_COARSE_LOCATION"/>

HTML5中通过navigator.geolocation对象获取地理位置信息

常用的navigator.geolocation对象有以下三种方法:

Js代码
  1. //获取当前地理位置
  2. navigator.geolocation.getCurrentPosition(success_callback_function,error_callback_function,position_options)
  3. //持续获取地理位置
  4. navigator.geolocation.watchPosition(success_callback_function,error_callback_function,position_options)
  5. //清除持续获取地理位置事件
  6. navigator.geolocation.clearWatch(watch_position_id)

其中success_callback_function为成功之后处理的函数,error_callback_function为失败之后返回的处理函数,参数position_options是配置项

JS中的代码

Js代码
  1. //定位
  2. functionget_location(){
  3. if(navigator.geolocation){
  4. navigator.geolocation.getCurrentPosition(show_map,handle_error,{enableHighAccuracy:false,maximumAge:1000,timeout:15000});
  5. }else{
  6. alert("YourbrowserdoesnotsupportHTML5geoLocation");
  7. }
  8. }
  9. functionshow_map(position){
  10. varlatitude=position.coords.latitude;
  11. varlongitude=position.coords.longitude;
  12. varcity=position.coords.city;
  13. //telnetlocalhost5554
  14. //geofix-82.41162928.054553
  15. //geofix-121.4535646.511194392
  16. //geonmea$GPGGA,001431.092,0118.2653,N,10351.1359,E,0,00,,-19.6,M,4.1,M,,0000*5B
  17. document.getElementById("Latitude").innerHTML="latitude:"+latitude;
  18. document.getElementById("Longitude").innerHTML="longitude:"+longitude;
  19. document.getElementById("City").innerHTML="city:"+city;
  20. }
  21. functionhandle_error(err){
  22. switch(err.code){
  23. case1:
  24. alert("permissiondenied");
  25. break;
  26. case2:
  27. alert("thenetworkisdownorthepositionsatellitescan'tbecontacted");
  28. break;
  29. case3:
  30. alert("timeout");
  31. break;
  32. default:
  33. alert("unknownerror");
  34. break;
  35. }
  36. }

其中position对象包含很多数据 error代码及选项 可以查看文档

● 构建HTML5离线应用

需要提供一个cache manifest文件,理出所有需要在离线状态下使用的资源

例如

Manifest代码
  1. CACHEMANIFEST
  2. #这是注释
  3. images/sound-icon.png
  4. images/background.png
  5. clock.html
  6. clock.css
  7. clock.js
  8. NETWORK:
  9. test.cgi
  10. CACHE:
  11. style/default.css
  12. FALLBACK:
  13. /files/projects/projects

在html标签中声明<html manifest="clock.manifest">

HTML5离线应用更新缓存机制

分为手动更新和自动更新2种

自动更新:

在cache manifest文件本身发生变化时更新缓存 资源文件发生变化不会触发更新

手动更新:

使用window.applicationCache

Js代码
  1. if(window.applicationCache.status==window.applicationCache.UPDATEREADY){
  2. window.applicationCache.update();

在线状态检测

HTML5 提供了两种检测是否在线的方式:navigator.online(true/false)online/offline事件。

在Android中构建离线应用

Java代码
  1. //开启应用程序缓存
  2. webSettingssetAppCacheEnabled(true);
  3. Stringdir=this.getApplicationContext().getDir("cache",Context.MODE_PRIVATE).getPath();
  4. //设置应用缓存的路径
  5. webSettings.setAppCachePath(dir);
  6. //设置缓存的模式
  7. webSettings.setCacheMode(WebSettings.LOAD_DEFAULT);
  8. //设置应用缓存的最大尺寸
  9. webSettings.setAppCacheMaxSize(1024*1024*8);
  10. //扩充缓存的容量
  11. publicvoidonReachedMaxAppCacheSize(longspaceNeeded,
  12. longtotalUsedQuota,WebStorage.QuotaUpdaterquotaUpdater){
  13. quotaUpdater.updateQuota(spaceNeeded*2);
  14. }


原文链接: http://johncookie.iteye.com/blog/1182459

更多相关文章

  1. android TextView的字体颜色设置的多种方法
  2. android webview 学习
  3. Android(安卓)中各种XML文件的作用
  4. Introducing Quick Search Box for Android
  5. 弹球效果动画
  6. android:屏幕自适应
  7. Android异步加载图片,并缓存到SD卡
  8. Android(安卓)OpenGL学习笔记(二)之----三角形的绘制.
  9. Android判断WIFI是否打开的方法

随机推荐

  1. 初学Android,使用原始资源(二十三)
  2. 我的Android进阶之旅------>android api
  3. 【Android导航决 千里之行 始于足下】问
  4. Android 2.3 Webkit
  5. 移植havlenapetr的ffmpeg-->Android播放
  6. Zxing二维码自定义修改关键代码
  7. android 命令获取手机中项目数据库
  8. pm grant 命令
  9. 使用Intent实现Activity之间传值与跳转
  10. 传智播客—Android(三) 数据存储之二 Share