首先声明,本教程参考国外网站(http://gonehybrid.com/how-to-use-pouchdb-sqlite-for-local-storage-in-your-ionic-app/)

代码书写格式上不一样!

1. ionic是跨平台app开发的工具(Cordova)的一个框架!

2.PouchDB是操作SQLite数据库的javascript库(跟mongoose操作mongodb一样)!

3.SQLite是一种轻量级的嵌入式数据库(数据库不需要你安装的,手机系统自带,你需要安装的就是SQLite插件)!

第一步 :安装Cordova 和 ionic  命令如下:

 

npm install -g cordova ionic

第二步:创建工程  命令如下:

ionic start birthday

第三步:安装SQLite插件和pouchdb.js库,并将pouchdb引入到index.html中。

//安装SQLite插件
cordova plugin add io.litehelpers.cordova.sqlitestorage //安装pouchdb库
bower install pouchdb //在index.html引入pouchdb
<script src="lib/pouchdb/dist/pouchdb.min.js"></script>

 第四步:环境基本OK了!接下来开始写代码了!

  首先配置service你也可以用factory,我用的service。在www/js/services.js 末尾去掉分号,添加一下代码。

.service('birthday', function () {
var _db;
//dateFix 函数是用来处理SQLite读出的数据的,因为SQLite的存储的数据结构层次优点不同,
//感兴趣的同学可以把数据打印出来研究下
function dateFix (result) {
var data = [];
  result.forEach(function (each) {
    data.push(each.doc);
  });
return data
}; return {
initDB: function () {
_db = new PouchDB('birthday', {adapter: 'websql'});
},
getAllBirthday: function (callback) {
_db.allDocs({include_docs: true}).then(function (result) {
callback(dateFix(result.rows));
})
},
addBirthday: function (birthday) {
_db.post(birthday);
},
removeBirthday: function (birthday) {
_db.remove(birthday);
}
}
});

  第五步:项目启动时我们要初始化数据库,所以我们在.run()方法里初始化数据库;

  有颜色的地方就是加的代码,第一处时注入我们之前定义的service('birthday')。现在注入进去。

               第二处表示$ionicPlatform准备好之后初始化数据库

.run(function($ionicPlatform, birthday) {
$ionicPlatform.ready(function() {
birthday.initDB();
// Hide the accessory bar by default (remove this to show the accessory bar above the keyboard
// for form inputs)
if (window.cordova && window.cordova.plugins && window.cordova.plugins.Keyboard) {
cordova.plugins.Keyboard.hideKeyboardAccessoryBar(true);
cordova.plugins.Keyboard.disableScroll(true); }
if (window.StatusBar) {
// org.apache.cordova.statusbar required
StatusBar.styleLightContent();
}
}

  

  第六步:开始controller里和views里的代码了

    工程中的路由都已经配置好了,我们直接修改她的controller和views就行了!

    展示生日我们用tab-dash.html, 对应的controller是DashCtrl;

    tab-dash.html中的代码修改如下:

<ion-view view-title="Dashboard">
<ion-content class="padding">
<div class="list card" ng-repeat="birthday in birthdays">
<div class="item item-divider">{{birthday.date}}</div>
<div class="item item-body">
<div>
{{birthday.name}}
</div>
</div>
</div>
</ion-content>
</ion-view>

  DashCtrl中修改如下:

.controller('DashCtrl', function($scope, birthday) {
$scope.birthdays = [];
$scope.init = function () {
birthday.getAllBirthday(function (data) {
console.log(data); //还没保存数据目前打印的是空数组
$scope.birthdays = data;
})
};
$scope.init();
})

  第七步:开始保存数据页面的controller和views编写了!

    存储数据的页面就用tab-account.html, controller就用AccountCtrl。

  tab-account.html的页面代码改成这样

<ion-view view-title="Account">
<ion-content>
<ion-list>
<div class="row">
<div class="col col-100" style="height:100px;"></div>
</div>
<div class="row">
<div class="col col-10">{{name}}</div>
<div class="col col-80"></div>
<div class="col col-10">{{date}}</div>
</div>
<div class="row">
<div class="col col-20">
姓名:
</div>
<div class="col col-80">
<input type="text" ng-model="a.name" style="border:1px solid black" >
</div>
</div>
<div class="row">
<div class="col col-20">
生日:
</div>
<div class="col col-80">
<input type="text" ng-model="a.date" style="border:1px solid black" >
</div>
</div>
<div class="row">
<div class="col col-20"></div>
<div class="col col-20">
<button ng-click="psotBirthday()">保存</button>
</div>
<div class="col col-60"></div>
</div>
</ion-list>
</ion-content>
</ion-view>

  接下来修改AccountCtrl

  代码改成这样:

.controller('AccountCtrl', function($scope, birthday) {
$scope.a = {}
$scope.psotBirthday = function () {
console.log($scope.a);
if (!$scope.a.name && !$scope.a.date) {
alert("姓名和日期不能为空!");
return;
};
birthday.addBirthday($scope.a);
$scope.a.name = '';
$scope.a.date = '';
}
});

  效果图:在此页面输入                              再点击Status显示如下:

                             

    OK到现在,我已经把通过pouchdb和SQLite在手机本地存储数据,取出数据的过程已经演示完成。至于删除也很简单的。

     我相信你可以自己去查看官方文档,自己去实现的!

  pouchdb官方API地址:http://pouchdb.com/api.html#delete_document

ionic 通过PouchDB + SQLite来实现app的本地存储(Local Storage)的更多相关文章

  1. [转]ionic 通过PouchDB + SQLite来实现app的本地存储(Local Storage)

    本文转自:http://www.cnblogs.com/ailen226/p/ionic.html 首先声明,本教程参考国外网站(http://gonehybrid.com/how-to-use-po ...

  2. [转]App离线本地存储方案

    App离线本地存储方案 原文地址:http://ask.dcloud.net.cn/article/166 HTML5+的离线本地存储有如下多种方案:HTML5标准方案:cookie.localsto ...

  3. [转]Dcloud App离线本地存储方案

    原文地址:http://ask.dcloud.net.cn/article/166 HTML5+的离线本地存储有如下多种方案:HTML5标准方案:cookie.localstorage.session ...

  4. ionic 运用pouchdb/sqlite 数据库做本地存储

    配置数据库环境需要3步: 1.安装slqite插件 在ionic 工程目录对应终端执行一下命令: npm install cordova-plugin-sqlite 2.安装pouchdb 在ioni ...

  5. Wijmo 5 + Ionic Framework之:费用跟踪 App

    Wijmo 5 + Ionic Framework之:费用跟踪 App 费用跟踪应用采用了Wijmo5和Ionic Framework创建,目的是构建一个hybird app. 我们基于<Mob ...

  6. Mobile first! Wijmo 5 + Ionic Framework之:费用跟踪 App

    费用跟踪应用采用了Wijmo5和Ionic Framework创建,目的是构建一个hybird app. 我们基于<Mobile first! Wijmo 5 + Ionic Framework ...

  7. ionic react-native和native开发移动app那个好

    ionic react-native和native开发移动app那个好 ? 移动端开发如何选型?这里介绍一下我眼中的ionic,react-native,native 三种移动端开发选型对比.欢迎大家 ...

  8. ionic react-native和native开发移动app到底那个好

    ionic react-native和native开发移动app那个好 ? 移动端开发如何选型?这里介绍一下我眼中的ionic,react-native,native 三种移动端开发选型对比.欢迎大家 ...

  9. ionic构建APP--简单操作实现APP制作

    ionic--基于AngularJS的app框架 1安装ionic .HBuilder创建APP项目,导入ionic的css,js(fonts)文件. .导入ionic.css和ionic.bundl ...

随机推荐

  1. PXC(percona xtradb cluster)新加节点避免SST的方法

    环境: node1:192.168.0.100  pxc节点 node2:192.168.0.101  新节点 把新加入的节点先建立为node1的从库,可以使用mysqldump或innobackup ...

  2. unity3d 第三人称视角的人物移动以及相机控制

    何谓第三人称?就像这样: 用wasd控制人物移动,同时保持在相机的中心.用鼠标右键与滚轮控制相机的角度和距离. 先说一下人物的移动: 首先给作为主角的单位加上 Charactor Controller ...

  3. 使SWT/JFace支持跨平台

    由于SWT的实现机制,在不同平台下,必须引用不同swt*.jar. 由于这个瓶颈,我们要为不同的平台编译不同的版本.但是这是可以避免的.这将是本文要讨论的内容. 我一共google到了3种soluti ...

  4. 【Treap】bzoj1588-HNOI2002营业额统计

    一.题目 Description 营业额统计 Tiger最近被公司升任为营业部经理,他上任后接受公司交给的第一项任务便是统计并分析公司成立以来的营业情况. Tiger拿出了公司的账本,账本上记录了公司 ...

  5. 20-ES6(3)class基本语法

    # Class基本语法 关于es6的class简介: ES6提供了更接近传统语言的写法,引入了Class(类)这个概念,作为对象的模板.通过class关键字,可以定义类.基本上,ES6的class可以 ...

  6. mysql服务器和配置优化

    一.存储引擎 mysql中有多种存储引擎,一般常见的有三种:   MyIsam InnoDB Memory 用途 快读 完整的事务支持 内存数据 锁 全表锁定 多种隔离级别的行锁 全表锁定 持久性 基 ...

  7. 读《编写可维护的JavaScript》第五章总结

    第五章 UI层的松耦合 5.1 什么是松耦合 在Web开发中,用户界面是由三个彼此隔离又相互作用的层定义的: HTML是用来定义页面的数据和语义 CSS用来给页面添加样式 JavaScript用来给页 ...

  8. linux启动流程及自定义gurb

    linux 启动流程 POST BIOS(boot sequence) 所选择的启动设备次序的MBR中是否有引导程序, ----> MBR(bootloader) 提供内核列表 -------& ...

  9. jquery总结06-动画事件03-淡入淡出效果

    .fadeout()淡出 .fadein()淡入 .fadeTaggle()淡入淡出切换 .fadeTo()淡入设定透明度 淡入淡出fadeIn与fadeOut都是修改元素样式的opacity属性,但 ...

  10. Makefile中头文件在依赖关系中作用

    摘于:http://bbs.csdn.net/topics/120024677 (1)在makefile的依赖关系中用不用体现.h头文件?(2)如果在依赖关系中要体现.h头文件,应该体现到什么层次?= ...