ReactNative跨平台开发系列教程:

带你从零学ReactNative开发跨平台App开发(一)

带你从零学ReactNative开发跨平台App开发(二)

带你从零学ReactNative开发跨平台App开发(三)

带你从零学ReactNative开发跨平台App开发(四)

带你从零学ReactNative开发跨平台App开发(五)

带你从零学ReactNative开发跨平台App开发(六)

带你从零学ReactNative开发跨平台App开发(七)

hot:更多>>

贴一个交流群的二维码,欢迎加入:

贴一个交流群二维码,欢迎加入

上篇说要来点真干货,由于接口没有整理好,我打算整理好接口直接部署到服务器上,这样大家可以一起使用,很遗憾,还没有整理好,不过,今天依然来点干货,只不过不是太干!

废话不多说,开始撸码,你准备好了吗?


这篇主要利用expo上集成的sqllite数据,以及一些缓存操作,做一个简单类型的备忘录!

主要用到依赖有

    "expo": "^23.0.4",
"pubsub-js": "^1.5.7",
"react": "16.0.0",
"react-native": "0.50.3",
"react-navigation": "^1.0.0-beta.22"

该项目源代码,全部推到github,点击这里获取!

这个demo虽然小,但是灵活的控制了数据流。希望大家可以有所收获。

犹豫本项目用到了SqlLite,在此我想喷一些那些搞移动端之想着掉接口的屌丝们!

下面简单介绍一些代码:(能把 这写代码看透彻的人,我给你点赞!)

//import liraries
import React, { Component } from 'react';
import {
View,
Text,
StyleSheet,
TouchableOpacity,
ListView,
} from 'react-native';
import PubSub from 'pubsub-js';
import MainItem from './MainItem';
import TodoManager from '../DataServer/TodoManager';
import AddTodo from './AddTodo';
import Footer from '../Component/Footer';
// create a component
class MainView extends Component {
static navigationOptions = {
title: '备忘录',
headerStyle: ({
backgroundColor: "#0EABE8",
elevation: 0,
}),
headerTitleStyle: ({
alignSelf: 'center'
}),
headerLeft: (
<TouchableOpacity onPress={() => {
PubSub.publish('all');
}}>
<Text>全选</Text>
</TouchableOpacity>
),
headerRight: (
<TouchableOpacity onPress={() => {
PubSub.publish('add');
}}>
<Text>添加</Text>
</TouchableOpacity>
)
}
componentDidMount() {
PubSub.subscribe('all', () => {
TodoManager.selectAll();
});
PubSub.subscribe('add', () => {
this.props.navigation.navigate('AddTodo');
});
TodoManager.setListener((todo) => {
this.setState({
ds: this.state.ds.cloneWithRows(todo),
});
});
TodoManager.setFinishListener((total) => {
this.setState({
selectCount: total,
});
});
TodoManager.getTodoInfo(); }
constructor(props) {
super(props);
const ds = new ListView.DataSource({ rowHasChanged: (r1, r2) => r1 !== r2 });
this.state = {
ds: ds.cloneWithRows([]),
isSelect: false,
selectCount: 0,
}
}
render() {
return (
<View style={styles.container}>
<ListView
dataSource={this.state.ds}
renderRow={(rowData) => {
console.log('===========rowData=========================');
console.log(rowData);
console.log('====================================');
return (
<View>
<MainItem
{...rowData}
clickSelect={(id) => {
console.log('====================================');
console.log('点击了id' + id);
console.log('====================================');
TodoManager.singleSelect(id);
}} />
<Text>{rowData.finish}</Text>
</View> );
}}
enableEmptySections={true}
/> <Footer selectCount={this.state.selectCount} />
</View>
);
}
} // define your styles
const styles = StyleSheet.create({
container: {
flex: 1,
justifyContent: 'center',
alignItems: 'center',
backgroundColor: '#fff',
},
}); //make this component available to the app
export default MainView;

关于操作SqlLite的Manager

import { SQLite } from 'expo';
class TodoManager {
constructor() {
this.db = SQLite.openDatabase('todoDB4');
this.db.transaction((tx) => {
const sql = "create table 'main'.'todo' ('id' integer not null primary key autoincrement,'name' text,'content' text,'finish' integer)";
tx.executeSql(sql, null, (tx, result) => {
console.log('====================================');
console.log('创建表成功');
console.log('====================================');
}, (tx, error) => {
console.log('====================================');
console.log('创建表失败' + error);
console.log('====================================');
});
});
} setListener(listener) {
this.listener = listener;
} setFinishListener(listener) {
this.finishListener = listener;
} getTodoInfo(callBack) {
console.log('====================================');
console.log('bbbbb');
console.log('====================================');
this.db.transaction((tx) => {
const sql = 'select * from todo';
tx.executeSql(sql, null, (tx, result) => {
const todos = result.rows._array;
console.log('=============todostodos=======================');
console.log(todos);
console.log('===================================='); //监听选中与否的变量变化
let selectCount = 0;
todos.map((value) => {
if (value.finish == 1) {
selectCount++;
}
});
//巧妙思路的变化
if (callBack) {
callBack(todos);
}
if (this.listener) {
console.log('====================================');
console.log('this.listener');
console.log('====================================');
this.listener(todos);
}
//回传过去
this.finishListener(selectCount);
}, (tx, error) => {
console.log('====================================');
console.log('查询失败' + error);
console.log('====================================');
//巧妙思路的变化
if (callBack) {
callBack([]);
}
if (this.listener) {
this.listener([]);
}
});
});
} addTodoInfo(info, callBack) {
this.db.transaction((tx) => {
const sql = `insert into todo(name,content,finish) values('${info.name}','${info.content}',0)`;
tx.executeSql(sql, null, (tx, result) => {
console.log('====================================');
console.log('添加成功');
console.log('====================================');
this.getTodoInfo();
if (callBack) {
callBack(true);
} }, (tx, error) => {
console.log('====================================');
console.log('添加失败' + error);
console.log('====================================');
if (callBack) {
callBack(false);
}
});
});
} delTodoInfo() {
// this.db.transaction((tx) => {
// const ids = info.id.join(',');
// const sql = `delete from todo where id in (${ids})`;
// tx.executeSql(sql, null, (tx, result) => {
// console.log('====================================');
// console.log('删除成功');
// console.log('====================================');
// if (callBack) {
// callBack(true);
// }
// this.getTodoInfo();
// }, (tx, error) => {
// console.log('====================================');
// console.log('删除失败' + error);
// console.log('====================================');
// if (callBack) {
// callBack(false);
// }
// }); // });
this.db.transaction((tx) => {
const sql = 'delete from todo where finish = 1';
tx.executeSql(sql, null, (tx, resultSet) => {
console.log('删除成功');
this.getTodoInfo();
})
})
} //全选
selectAll() {
this.db.transaction((tx) => {
const sql = 'select * from todo';
tx.executeSql(sql, null, (tx, result) => {
const array = result.rows._array;
let length = array.length;
let slength = 0;
array.map((value, key) => {
if (value.finish == 1) {
slength++;
}
});
if (slength == length) {
//取消全选
const sql = 'update todo set finish=0';
tx.executeSql(sql, null, (tx, resultSet) => {
if (resultSet) {
this.getTodoInfo();
}
}, (tx, error) => {
console.log('====================================');
console.log('取消全选失败' + error);
console.log('====================================');
}); } else {
//全选
const sql = 'update todo set finish=1';
tx.executeSql(sql, null, (tx, resultSet) => {
if (resultSet) {
this.getTodoInfo();
}
}, (tx, error) => {
console.log('====================================');
console.log('全选失败' + error);
console.log('====================================');
});
} }, (tx, error) => {
console.log('====================================');
console.log('全选失败' + error);
console.log('====================================');
});
});
} //单选
singleSelect(id) {
//先根据传过来的id查询一下
this.db.transaction((tx) => {
const sql = `select * from todo where id=${id}`;
tx.executeSql(sql, null, (tx, resultSet) => {
//修改其状态
const todo = resultSet.rows._array[0];
const finish = todo.finish ? 0 : 1;//修改
const sql = `update todo set finish=${finish} where id=${id}`;
tx.executeSql(sql, null, (tx, resultSet) => {
console.log('==============aaaa======================');
console.log('aaaa');
console.log('====================================');
this.getTodoInfo();
})
}, (tx, error) => {
console.log('====================================');
console.log('单选失败' + error);
console.log('====================================');
});
}); } }
export default new TodoManager();

细节就不详细介绍了,代码github上自己好好研究!


后续文章持续更新,敬请期待!

文章为作者原创,转载请注明出处。

带你从零学ReactNative开发跨平台App开发(十一)的更多相关文章

  1. 带你从零学ReactNative开发跨平台App开发(二)

    ReactNative跨平台开发系列教程: 带你从零学ReactNative开发跨平台App开发(一) 带你从零学ReactNative开发跨平台App开发(二) 带你从零学ReactNative开发 ...

  2. 带你从零学ReactNative开发跨平台App开发(一)

    ReactNative跨平台开发系列教程: 带你从零学ReactNative开发跨平台App开发(一) 带你从零学ReactNative开发跨平台App开发(二) 带你从零学ReactNative开发 ...

  3. 带你从零学ReactNative开发跨平台App开发-[react native 仿boss直聘](十三)

    ReactNative跨平台开发系列教程: 带你从零学ReactNative开发跨平台App开发(一) 带你从零学ReactNative开发跨平台App开发(二) 带你从零学ReactNative开发 ...

  4. 带你从零学ReactNative开发跨平台App开发(十)

    ReactNative跨平台开发系列教程: 带你从零学ReactNative开发跨平台App开发(一) 带你从零学ReactNative开发跨平台App开发(二) 带你从零学ReactNative开发 ...

  5. 带你从零学ReactNative开发跨平台App开发(九)

    ReactNative跨平台开发系列教程: 带你从零学ReactNative开发跨平台App开发(一) 带你从零学ReactNative开发跨平台App开发(二) 带你从零学ReactNative开发 ...

  6. 带你从零学ReactNative开发跨平台App开发[expo 打包发布](八)

    ReactNative跨平台开发系列教程: 带你从零学ReactNative开发跨平台App开发(一) 带你从零学ReactNative开发跨平台App开发(二) 带你从零学ReactNative开发 ...

  7. 带你从零学ReactNative开发跨平台App开发(七)

    ReactNative跨平台开发系列教程: 带你从零学ReactNative开发跨平台App开发(一) 带你从零学ReactNative开发跨平台App开发(二) 带你从零学ReactNative开发 ...

  8. 带你从零学ReactNative开发跨平台App开发(六)

    ReactNative跨平台开发系列教程: 带你从零学ReactNative开发跨平台App开发(一) 带你从零学ReactNative开发跨平台App开发(二) 带你从零学ReactNative开发 ...

  9. 带你从零学ReactNative开发跨平台App开发(五)

    ReactNative跨平台开发系列教程: 带你从零学ReactNative开发跨平台App开发(一) 带你从零学ReactNative开发跨平台App开发(二) 带你从零学ReactNative开发 ...

随机推荐

  1. Python字典按值排序、包含字典的列表按字典值排序的方法

    operator.itemgetter函数 operator模块提供的itemgetter函数用于获取对象的哪些维的数据,参数为一些序号(即需要获取的数据在对象中的序号),要注意,operator.i ...

  2. Java之IO(一)InputStream和OutputStream

    转载请注明源出处:http://www.cnblogs.com/lighten/p/6964702.html 1.前言 计算机的IO操作一直都是比较重要的一环,IO顾名思义,就是输入输出流.不管是磁盘 ...

  3. Vue路由router-link的使用

    Vue路由router-link的使用 相关Html: <!DOCTYPE html> <html lang="en"> <head> < ...

  4. ES6-Array

    /* * 数组解构赋值: * ES6允许按照一定模式,从数组和对象中提取值,对变量进行赋值,这种被称为解构. * 示例如下: */ var [a,b,c] = [1,2,3]; console.log ...

  5. 数据库--oracle安装配置(本地安装的步骤及各种问题解决方案)

    oracle版本:Oracle 11g 本地电脑配置:安装内存8G 64为操作系统win8.1 下载Oracle 11g压缩包: 1 网址http://www.oracle.com/technetwo ...

  6. GRU

    GRU模型(比LSTM减少了计算量) LSTM的模型,LSTM的重复网络模块的结构很复杂,它实现了三个门计算,即遗忘门.输入门和输出门. 而GRU模型如下,它只有两个门了,分别为更新门和重置门,即图中 ...

  7. Innosetup的状态页面和向导页面解释

    1.安装: CurStepChanged所对应的全部状态:3种 1.1. CurStep=ssInstall         --是在程序实际安装前(所有配置都准备好了)     1.2. CurSt ...

  8. seajs源码分析(一)---整体结构以及module.js

    1,seajs的主要内容在module.js内部,最开始包含这么几个东西 var cachedMods = seajs.cache = {} var anonymousMeta var fetchin ...

  9. HDFS:分布式文件系统

    HDFS是GFS的简化版,它同一时刻只允许一个用户对同一文件进行追加写操作(GFS允许并发写).它适合存储大文件,并提供高吞吐量的顺序读/写访问. 它的早期版本两大问题,例如:单点失效和水平扩展不佳. ...

  10. layer相关使用

    父子页面传参数 转自:https://blog.csdn.net/babyxue/article/details/76854106 1.父页面打开子页面并向子页面传参数 function setCho ...