时间:2021-07-01 10:21:17 帮助过:6人阅读
执行命令后,打开 http://127.0.0.1:8000/ 。如果看到了下面的图片,就表示该应用安装成功。
通过打开浏览器的控制台,你可以查看任何错误或者一些确认信息。
用编辑器打开 index.html
,添加PouchDB的引用脚本:
- <code class="language-html hljs xml" style="background-color: #D6DBDF; border: 0; border-radius: 4px; color: #4f424c; font-size: 90%; padding-top: 0.5em; padding-right: 0.5em; padding-bottom: 0.5em; padding-left: 0.5em; display: block; overflow-x: auto; background: #e7e9db; -webkit-text-size-adjust: none;"><span class="hljs-tag" style="color: #ef6155;"><<span class="hljs-title" style="color: #ef6155;">script</span> <span class="hljs-attribute" style="color: #ef6155;">src</span>=<span class="hljs-value" style="color: #48b685;">"//cdn.jsdelivr.net/pouchdb/3.5.0/pouchdb.min.js"</span>></span><span class="undefined"></span><span class="hljs-tag" style="color: #ef6155;"></<span class="hljs-title" style="color: #ef6155;">script</span>></span>
- <span class="hljs-tag" style="color: #ef6155;"><<span class="hljs-title" style="color: #ef6155;">script</span> <span class="hljs-attribute" style="color: #ef6155;">src</span>=<span class="hljs-value" style="color: #48b685;">"js/base.js"</span>></span><span class="undefined"></span><span class="hljs-tag" style="color: #ef6155;"></<span class="hljs-title" style="color: #ef6155;">script</span>></span>
- <span class="hljs-tag" style="color: #ef6155;"><<span class="hljs-title" style="color: #ef6155;">script</span> <span class="hljs-attribute" style="color: #ef6155;">src</span>=<span class="hljs-value" style="color: #48b685;">"js/app.js"</span>></span><span class="undefined"></span><span class="hljs-tag" style="color: #ef6155;"></<span class="hljs-title" style="color: #ef6155;">script</span>></span>
- </code>
现在PouchDB已经成功安装到应用内,是不是很简单。你可以在该应用上使用PouchDB的所有功能。
接下来,我们的主要代码都在app.js
文件内完成。 开始添加待办前,需要创建一个数据库。PouchDB创建一个新数据库的脚本如下:
- <code class="language-javascript hljs" style="background-color: #D6DBDF; border: 0; border-radius: 4px; color: #4f424c; font-size: 90%; padding-top: 0.5em; padding-right: 0.5em; padding-bottom: 0.5em; padding-left: 0.5em; display: block; overflow-x: auto; background: #e7e9db; -webkit-text-size-adjust: none;"><span class="hljs-comment" style="color: #776e71;">// EDITING STARTS HERE (you dont need to edit anything above this line)</span>
- <span class="hljs-keyword" style="color: #815ba4;">var</span> db = <span class="hljs-keyword" style="color: #815ba4;">new</span> PouchDB(<span class="hljs-string" style="color: #48b685;">'todos'</span>);
- <span class="hljs-keyword" style="color: #815ba4;">var</span> remoteCouch = <span class="hljs-literal" style="color: #f99b15;">false</span>;
- </code>
由于PouchDB是一个文档型数据库,与关系型数据库不同的地方是,不需要创建元数据。给定一个名称后,PouchDB就立即创建一个数据库,然后你就可以往数据库里写数据了。
首先我们需要提供一个输入待办todos到数据库的方法。当用户在输入完todo内容,按下回车
后,系统将调用addTodo
方法,实现将待办todos添加到数据库内。具体的实现代码如下:
- <code class="language-javascript hljs" style="background-color: #D6DBDF; border: 0; border-radius: 4px; color: #4f424c; font-size: 90%; padding-top: 0.5em; padding-right: 0.5em; padding-bottom: 0.5em; padding-left: 0.5em; display: block; overflow-x: auto; background: #e7e9db; -webkit-text-size-adjust: none;"><span class="hljs-function" style="color: #06b6ef;"><span class="hljs-keyword" style="color: #815ba4;">function</span> <span class="hljs-title" style="color: #776e71;">addTodo</span><span class="hljs-params" style="color: #f99b15;">(text)</span> </span>{
- <span class="hljs-keyword" style="color: #815ba4;">var</span> todo = {
- _id: <span class="hljs-keyword" style="color: #815ba4;">new</span> <span class="hljs-built_in" style="color: #f99b15;">Date</span>().toISOString(),
- title: text,
- completed: <span class="hljs-literal" style="color: #f99b15;">false</span>
- };
- db.put(todo, <span class="hljs-function" style="color: #06b6ef;"><span class="hljs-keyword" style="color: #815ba4;">function</span> <span class="hljs-title" style="color: #776e71;">callback</span><span class="hljs-params" style="color: #f99b15;">(err, result)</span> </span>{
- <span class="hljs-keyword" style="color: #815ba4;">if</span> (!err) {
- <span class="hljs-built_in" style="color: #f99b15;">console</span>.log(<span class="hljs-string" style="color: #48b685;">'Successfully posted a todo!'</span>);
- }
- });
- }
- </code>
在PouchDB里,每一条数据都需要一个唯一的主键_id
。任何提交的数据里,如果有相同的_id
,PouchDB都将更新相同_id
下的数据,否则创建一条新的_id
数据。在这里,我们使用创建的时间做为_id
主键,这样的好处是既能保证_id
的唯一性,又能在方便的在数据库里进行排序。如果你不想自己生成_id
值,可以使用db.post()
方法提交不包含_id
的数据。创建的数据最少只需要_id
该字段,最多理论上可以有无数个。
回调函数 callback
将在数据完成插入到数据库后执行,这里的完成可能是成功插入到数据库,也可能是出现错误插入失败的完成。在回调函数里,如果 err
非空,将代表插入的数据失败,同时包含失败的原因,否则就是插入成功,result里将返回成功后的数据_id
和_rev
。_rev
是这条数据的版本号。
在模板代码里已经提供了一个 redrawTodosUI
方法,用于显示待办列表组,我们只需要提供一个从数据库里取得待办列表数据的功能。在这里,我们可以使用方法 db.allDocs
简单的从数据库里取得所有待办列表数据。 PouchDB在返回数据列表时,仅包含了_id
和_revs
两荐数据,通过include_docs
选项可以让PouchDB在返回数据列表时包含数据的详细信息。descending
选项可以让PouchDB对结果集进行倒序操作。
- <code class="language-javascript hljs" style="background-color: #D6DBDF; border: 0; border-radius: 4px; color: #4f424c; font-size: 90%; padding-top: 0.5em; padding-right: 0.5em; padding-bottom: 0.5em; padding-left: 0.5em; display: block; overflow-x: auto; background: #e7e9db; -webkit-text-size-adjust: none;"><span class="hljs-function" style="color: #06b6ef;"><span class="hljs-keyword" style="color: #815ba4;">function</span> <span class="hljs-title" style="color: #776e71;">showTodos</span><span class="hljs-params" style="color: #f99b15;">()</span> </span>{
- db.allDocs({include_docs: <span class="hljs-literal" style="color: #f99b15;">true</span>, descending: <span class="hljs-literal" style="color: #f99b15;">true</span>}, <span class="hljs-function" style="color: #06b6ef;"><span class="hljs-keyword" style="color: #815ba4;">function</span><span class="hljs-params" style="color: #f99b15;">(err, doc)</span> </span>{
- redrawTodosUI(doc.rows);
- });
- }
- </code>
添加完上面的代码后,就可以通过刷新页面查看你所有添加的待办todos列表。
我们不想每次更新一个待办列表都要刷新一下页面。更加人性化的处理是,每次更新数据时,自动更新UI界面。由于PouchDB需要同步数据到远程数据库,因此需要在服务器数据被修改时同步更新到客户端。通过db.changes
可以实现监听数据库的更新。可以在remoteCouch
和addTodo
代码间添加下面的代码:
- <code class="language-javascript hljs" style="background-color: #D6DBDF; border: 0; border-radius: 4px; color: #4f424c; font-size: 90%; padding-top: 0.5em; padding-right: 0.5em; padding-bottom: 0.5em; padding-left: 0.5em; display: block; overflow-x: auto; background: #e7e9db; -webkit-text-size-adjust: none;"><span class="hljs-keyword" style="color: #815ba4;">var</span> remoteCouch = <span class="hljs-literal" style="color: #f99b15;">false</span>;
- db.changes({
- since: <span class="hljs-string" style="color: #48b685;">'now'</span>,
- live: <span class="hljs-literal" style="color: #f99b15;">true</span>
- }).on(<span class="hljs-string" style="color: #48b685;">'change'</span>, showTodos);
- <span class="hljs-comment" style="color: #776e71;">// We have to create a new todo document and enter it in the database</span>
- <span class="hljs-function" style="color: #06b6ef;"><span class="hljs-keyword" style="color: #815ba4;">function</span> <span class="hljs-title" style="color: #776e71;">addTodo</span><span class="hljs-params" style="color: #f99b15;">(text)</span> </span>{
- </code>
现在,每一次的数据库更新,我们都可以重新渲染UI来显示新的数据。选项live
表示该方法将一直监控运行。输入新的待办后,应用将立即显示新添加的待办项。
当选中checkbox后,checkboxChanged
方法将会被执行。添加下面的代码实现编辑待办事项:
- <code class="language-javascript hljs" style="background-color: #D6DBDF; border: 0; border-radius: 4px; color: #4f424c; font-size: 90%; padding-top: 0.5em; padding-right: 0.5em; padding-bottom: 0.5em; padding-left: 0.5em; display: block; overflow-x: auto; background: #e7e9db; -webkit-text-size-adjust: none;"><span class="hljs-function" style="color: #06b6ef;"><span class="hljs-keyword" style="color: #815ba4;">function</span> <span class="hljs-title" style="color: #776e71;">checkboxChanged</span><span class="hljs-params" style="color: #f99b15;">(todo, event)</span> </span>{
- todo.completed = event.target.checked;
- db.put(todo);
- }
- </code>
该方法和创建一个新的待办列表很像,不同的是该待办必须包含一个_rev
项(还包括_id
项),否则在提交到PouchDB时,就会提交失败。
现在,你可以通过选中多选框来表明待办项完成,或者去掉选中来重新进入待办。
想要删除一个待办数据,可以调用 db.remove
方法。
- <code class="language-javascript hljs" style="background-color: #D6DBDF; border: 0; border-radius: 4px; color: #4f424c; font-size: 90%; padding-top: 0.5em; padding-right: 0.5em; padding-bottom: 0.5em; padding-left: 0.5em; display: block; overflow-x: auto; background: #e7e9db; -webkit-text-size-adjust: none;"><span class="hljs-function" style="color: #06b6ef;"><span class="hljs-keyword" style="color: #815ba4;">function</span> <span class="hljs-title" style="color: #776e71;">deleteButtonPressed</span><span class="hljs-params" style="color: #f99b15;">(todo)</span> </span>{
- db.remove(todo);
- }
- </code>
跟编辑一个数据一样,删除一条数据也需要同时提供 _id
和 _rev
项。可能大家都会注意到,我们这里直接把整个对像传递到了方法 db.remove
方法内,实际上,PouchDB只会关注传递对像里的 _id
和 _rev
两项,如果你自己构建一个对像 {_id: todo._id, _rev: todo._rev}
,效果也是一样的,只是为了方便而以。
编辑一条数据时, todoBlurred
方法将会被执行。如果用户输入了一个空白的标题待办,我们将会删除该条数据,否则只是更新下待办项。
- <code class="language-javascript hljs" style="background-color: #D6DBDF; border: 0; border-radius: 4px; color: #4f424c; font-size: 90%; padding-top: 0.5em; padding-right: 0.5em; padding-bottom: 0.5em; padding-left: 0.5em; display: block; overflow-x: auto; background: #e7e9db; -webkit-text-size-adjust: none;"><span class="hljs-function" style="color: #06b6ef;"><span class="hljs-keyword" style="color: #815ba4;">function</span> <span class="hljs-title" style="color: #776e71;">todoBlurred</span><span class="hljs-params" style="color: #f99b15;">(todo, event)</span> </span>{
- <span class="hljs-keyword" style="color: #815ba4;">var</span> trimmedText = event.target.value.trim();
- <span class="hljs-keyword" style="color: #815ba4;">if</span> (!trimmedText) {
- db.remove(todo);
- } <span class="hljs-keyword" style="color: #815ba4;">else</span> {
- todo.title = trimmedText;
- db.put(todo);
- }
- }
- </code>
现在我们开始实现同步功能。首先需要安装CouchDB,你可以自己在本地安装 CouchDB(1.3+) 或者使用一个在线的 CouchDB服务,比如 IrisCouch。
为了实现同步数据功能,需要在CouchDB里打开跨域访问的功能。CouchDB默认是以管理员身份安装,并不需要提供用户名和密码,如果你设置了用户名和密码,在连接同步时,也需要一起提供。下面的代码里,如果是本地安装,需要将 myname.iriscouch.com
替换成本地CouchDB的地址(比如:127.0.0.1:5984
)
你也可以通过使用curl 或者 Futon web 接口来打开CORS。为了方便,我们提供了一个 Node 脚本 add-cors-to-couchdb。执行一下就可以打开跨域访问功能。
- <code class="language-bash hljs" style="background-color: #D6DBDF; border: 0; border-radius: 4px; color: #4f424c; font-size: 90%; padding-top: 0.5em; padding-right: 0.5em; padding-bottom: 0.5em; padding-left: 0.5em; display: block; overflow-x: auto; background: #e7e9db; -webkit-text-size-adjust: none;">$ npm install -g add-cors-to-couchdb
- $ add-cors-to-couchdb
- </code>
如果你的数据库地址不是 127.0.0.1:5984
:
- <code class="language-bash hljs" style="background-color: #D6DBDF; border: 0; border-radius: 4px; color: #4f424c; font-size: 90%; padding-top: 0.5em; padding-right: 0.5em; padding-bottom: 0.5em; padding-left: 0.5em; display: block; overflow-x: auto; background: #e7e9db; -webkit-text-size-adjust: none;">$ add-cors-to-couchdb http://me.iriscouch.com -u myusername -p mypassword
- </code>
通过 http://localhost:5984/_utils/config.html 你可以检测是否打开CORS功能。你会看到类似的效果:
现在我们就可以开始真正的同步功能。回到 app.js
,我们需要提供一个远程数据库的地址。记得把 user
, pass
和 myname.iriscouch.com
替换成你CouchDB的帐户信息。
- <code class="language-javascript hljs" style="background-color: #D6DBDF; border: 0; border-radius: 4px; color: #4f424c; font-size: 90%; padding-top: 0.5em; padding-right: 0.5em; padding-bottom: 0.5em; padding-left: 0.5em; display: block; overflow-x: auto; background: #e7e9db; -webkit-text-size-adjust: none;"><span class="hljs-comment" style="color: #776e71;">// EDITING STARTS HERE (you dont need to edit anything above this line)</span>
- <span class="hljs-keyword" style="color: #815ba4;">var</span> db = <span class="hljs-keyword" style="color: #815ba4;">new</span> PouchDB(<span class="hljs-string" style="color: #48b685;">'todos'</span>);
- <span class="hljs-keyword" style="color: #815ba4;">var</span> remoteCouch = <span class="hljs-string" style="color: #48b685;">'http://user:pass@mname.iriscouch.com/todos'</span>;
- </code>
实现同步功能的代码:
- <code class="language-javascript hljs" style="background-color: #D6DBDF; border: 0; border-radius: 4px; color: #4f424c; font-size: 90%; padding-top: 0.5em; padding-right: 0.5em; padding-bottom: 0.5em; padding-left: 0.5em; display: block; overflow-x: auto; background: #e7e9db; -webkit-text-size-adjust: none;"><span class="hljs-function" style="color: #06b6ef;"><span class="hljs-keyword" style="color: #815ba4;">function</span> <span class="hljs-title" style="color: #776e71;">sync</span><span class="hljs-params" style="color: #f99b15;">()</span> </span>{
- syncDom.setAttribute(<span class="hljs-string" style="color: #48b685;">'data-sync-state'</span>, <span class="hljs-string" style="color: #48b685;">'syncing'</span>);
- <span class="hljs-keyword" style="color: #815ba4;">var</span> opts = {live: <span class="hljs-literal" style="color: #f99b15;">true</span>};
- db.replicate.to(remoteCouch, opts, syncError);
- db.replicate.from(remoteCouch, opts, syncError);
- }
- </code>
db.replicate()
告诉 PouchDB从 from
remoteCouch
传输所有文档到本地或者将本地所有文档传输到to
remoteCouch
。 remoteCouch
可以是一个合法的地址串,也可以是另一个PouchDB实例。PouchDB将会执行两次同步:一次接收从远程数据库里传输过来的数据,另一次就是提交本地修改到远程数据库里。live
标识用于告诉PouchDB持续执行更同步动作,也就是实时监控数据库的变化。当同步完成后,将会有一个会调函数接口。对于实时的同步,可能需要处理一些异常情况,比如链接丢失或者取消同步。
现在你可以在另一个窗口打开应用the todo app,查看两边的待办列表是否同步一致。你也可以通过CouchDB提供的 Futon 管理页面,查看更新的数据。
完成上面的步骤,你就成功实现了一个基于PouchDB的应用。这是一个很基础的例子,现实生产中的应用可能比这个要复杂得多,包括错误的验证,登录等。但通过这样一个例子,完全可以让你了解PouchDB的工作原理。如果你有更多的疑问,可以与联系IRC 或者 the mailing list
该文档使用小书匠编辑器编辑完成,并通过客户端发布到博客园系统,
原英文地址:http://pouchdb.com/getting-started.html
中文地址转载地址: http://www.cnblogs.com/suziwen/p/4507684.html
转载请注明地址。
pouchdb快速入门教程
标签: