异步存储是一个简单的、异步的、持久的、全局的、键-值存储系统。它应该会代替本地存储被使用。
由于异步存储是全局性的,建议您在异步存储之上使用抽象体,而不是对任何轻微用法直接使用异步存储。
在本地 iOS 实现上 JS 代码是一个简单的外观模式,用来提供一个清晰的 JS API,真正的错误对象,和简单的非多元化功能。每个方法返回一个 Promise
对象。
static **getItem**(key: string, callback: (error: ?Error, result: ?string) => void)
如果有任何一个错误,获取 key
并传递 callback
的结果,返回一个 Promise
对象。
static **setItem**(key: string, value: string, callback: ?(error: ?Error) => void)
如果有任何一个错误,获取 key
并在结束时调用 callback
函数,返回一个 Promise
对象。
static **removeItem**(key: string, callback: ?(error: ?Error) => void)
返回一个 Promise
对象。
static **mergeItem**(key: string, value: string, callback: ?(error: ?Error) => void)
将现有值与输入值进行合并,假设它们是 stringified json,返回一个 Promise
对象。
所有本地实现不支持。
static **clear**(callback: ?(error: ?Error) => void)
为所有客户、函数库等清除所有的异步存储。你可能不想调用这个-使用 removeItem 或者 multiRemove 来清除只属于你的键值。返回一个 Promise
对象。
static **getAllKeys**(callback: (error: ?Error) => void)
为调用者、函数库等获取系统已知的所有键值。返回一个 Promise
对象。
static **multiGet**(keys: Array<string>, callback: (errors: ?Array<Error>, result: ?Array<Array<string>>) => void) multiGet利用一个键值对的数组调用回调函数来获取multiSet的输入格式。返回一个 `Promise` 对象。 multiGet(["k1", "k2"], cb) -> cb([["k1", "val1"], ["k2", "val2"]]) static **multiSet**(keyValuePairs: Array<Array<string>>, callback: ?(errors: ?Array<Error>) => void)
multiSet 和 multiMerge 利用键值对的数组匹配multiGet的输出。返回一个 Promise
对象。例如,
multiSet([["k1", "val1"], ["k2", "val2"]], cb); static **multiRemove**(keys: Array<string>, callback: ?(errors: ?Array<Error>) => void)
删除键值数组中所有的键值。返回一个 Promise
对象。
static **multiMerge**(keyValuePairs: Array<Array<string>>, callback: ?(errors: ?Array<Error>) => void)
将现有值与输入值进行合并,假设它们是 stringified json,返回一个 Promise
对象。
所有本地实现不支持。
dit on GitHub
"use strict"; var React = require("react-native"); var { AsyncStorage, PickerIOS, Text, View } = React; var PickerItemIOS = PickerIOS.Item; var STORAGE_KEY = "@AsyncStorageExample:key"; var COLORS = ["red", "orange", "yellow", "green", "blue"]; var BasicStorageExample = React.createClass({ componentDidMount() { AsyncStorage.getItem(STORAGE_KEY) .then((value) => { if (value !== null){ this.setState({selectedValue: value}); this._appendMessage("Recovered selection from disk: " + value); } else { this._appendMessage("Initialized with no selection on disk."); } }) .catch((error) => this._appendMessage("AsyncStorage error: " + error.message)) .done(); }, getInitialState() { return { selectedValue: COLORS[0], messages: [], }; }, render() { var color = this.state.selectedValue; return ( <View> <PickerIOS selectedValue={color} onValueChange={this._onValueChange}> {COLORS.map((value) => ( <PickerItemIOS key={value} value={value} label={value} /> ))} </PickerIOS> <Text> {"Selected: "} <Text style={{color}}> {this.state.selectedValue} </Text> </Text> <Text>{" "}</Text> <Text onPress={this._removeStorage}> Press here to remove from storage. </Text> <Text>{" "}</Text> <Text>Messages:</Text> {this.state.messages.map((m) => <Text>{m}</Text>)} </View> ); }, _onValueChange(selectedValue) { this.setState({selectedValue}); AsyncStorage.setItem(STORAGE_KEY, selectedValue) .then(() => this._appendMessage("Saved selection to disk: " + selectedValue)) .catch((error) => this._appendMessage("AsyncStorage error: " + error.message)) .done(); }, _removeStorage() { AsyncStorage.removeItem(STORAGE_KEY) .then(() => this._appendMessage("Selection removed from disk.")) .catch((error) => { this._appendMessage("AsyncStorage error: " + error.message) }) .done(); }, _appendMessage(message) { this.setState({messages: this.state.messages.concat(message)}); }, }); exports.title = "AsyncStorage"; exports.description = "Asynchronous local disk storage."; exports.examples = [ { title: "Basics - getItem, setItem, removeItem", render(): ReactElement { return <BasicStorageExample />; } }, ];
jQuery Mobile CSS 类 jQuery CSS 类 jQuery Mobile CSS 类来设置不同元素的样式。 以下列表包含了通用的 CSS 样式:全局类 以下...
Android 架构Android 操作系统是一个软件组件的栈,在架构图中它大致可以分为五个部分和四个主要层。Linux内核在所有层的最底下...
附录 A安装 Storm 客户端Storm 客户端能让我们使用命令管理集群中的拓扑。按照以下步骤安装 Storm 客户端:从 Storm 站点下载最...
Neo4j CQL MATCH 命令用于从数据库获取有关节点和属性的数据从数据库获取有关节点,关系和属性的数据 MATCH 命令语法: MATCH ( ...
Access包括一个导航控件,使您可以轻松地在数据库中的各种表单和报告之间切换。导航表单仅仅是包含导航控件的表单。导航表格是任...
Microsoft Access是来自Microsoft的数据库管理系统(DBMS),它将关系Microsoft Jet数据库引擎与图形用户界面和软件开发工具相结...
"INDEXED BY index-name" 子句规定必须需要命名的索引来查找前面表中值。 如果索引名 index-name 不存在或不能用于查询,然后 SQ...