我正在创建一个CouchApp,并对远程数据库和创建PouchDB对象有疑问。
我目前使用以下方法创建一个新的PouchDB对象:
var db = new PouchDB(' htps://username.cloudant.com/database');
但我宁愿将其实例化为:
var db = new PouchDB(' / database');
或
var db = new PouchDB('数据库');
我的猜测是PouchDB将其视为本地数据库而不是远程数据库。我的想法是否正确,我怎样才能得到我想要的结果?我想删除URL的主机名,因为我想保持一切可移植性并将其复制到其他服务器上。
答案 0 :(得分:2)
由于您定义了vhost,因此可以使用以下解决方法mabye:
var url = new URL(window.location.href);
var host = url.host;
var db = new PouchDB(host+"/database");
答案 1 :(得分:0)
我目前使用以下方法创建一个新的PouchDB对象:
var db = new PouchDB(' htps://username.cloudant.com/database');
但我宁愿将其实例化为:
var db = new PouchDB('数据库');
嗯,这不是个人偏好的问题,您可能需要远程数据库,本地数据库或两者兼而有之。
基本上,作为开发人员,您可能需要远程数据库:
const remoteDB=new PouchDB('https://username.cloudant.com/database')
此外,您可能需要一个本地数据库:
const localDB=new PouchDB('localDatabase')
然后,您可能需要sync
远程和本地数据库。实际上,syncing
是 PouchDB真正发光的。例如,同步可以这样做:
localDB.sync(remoteDB,{live:true,retry:true}).on('complete',()=>{
console.log('sync done')
}).on('change',change=>{
console.log('Something changed -> ',change)
}).on('paused',info=>{
console.log('Sync paused -> ',info)
}).on('active',info=>{
console.log('Sync is active again -> ',info)
}).on('error',err=>{
throw new Error(err)
})
您可以read on了解更多信息。
答案 2 :(得分:0)
我能够弄清楚)
我正在使用create-react-app
,并希望使用proxy
指令,因此我可以将所有pouchdb
请求重定向到我的/couchdb1
端点,并避免所有CORS问题。
所以你去了:
const COUCHDB_ROOT = '/couchdb1';
const remoteDB = new PouchDB(COUCHDB_ROOT + '/userdb-626f62', {
adapter: 'http',
fetch: (url, opts) => {
if (typeof url === 'string') {
return PouchDB.fetch(COUCHDB_ROOT + url.split(COUCHDB_ROOT)[1], opts)
} else {
throw new Error('The url could be of a Request type.'); // TODO
}
},
auth: {
username: 'bob',
password: 'bob',
},
skip_setup: true,
});