我正在创建一个使用sqlite作为其数据源的回送离线同步的cordova应用程序。这是我的代码:
lbclient \ datasources.json:
{
"remote": {
"connector": "remote"
},
"sqlite": {
"connector": "sqlite",
"location": "default",
"file_name": "sqlite.sqlite3",
"debug": false
}
}
lbclient \ lbclient.js:
'use strict';
var loopback = require('loopback');
var boot = require('loopback-boot');
var client = module.exports = loopback();
if (client.connectorRegistry) {
console.log(client.connectorRegistry);
}
client.connector('sqlite', require('loopback-connector-cordova-sqlite'));
boot(client);
在我的browser.bundle.js上,我注意到try块执行了两次
app.dataSource = function(name, config) {
try {
var ds = dataSourcesFromConfig(name, config, this.connectors, this.registry);
this.dataSources[name] =
this.dataSources[classify(name)] =
this.dataSources[camelize(name)] = ds;
ds.app = this;
return ds;
} catch (err) {
if (err.message) {
err.message = g.f('Cannot create data source %s: %s',
JSON.stringify(name), err.message);
}
throw err;
}
};
这里是dataSourcesFromConfig:
function dataSourcesFromConfig(name, config, connectorRegistry, registry) {
var connectorPath;
assert(typeof config === 'object',
'can not create data source without config object');
if (typeof config.connector === 'string') {
name = config.connector;
if (connectorRegistry[name]) {
config.connector = connectorRegistry[name];
} else {
connectorPath = path.join(__dirname, 'connectors', name + '.js');
if (fs.existsSync(connectorPath)) {
config.connector = require(connectorPath);
}
}
if (config.connector && typeof config.connector === 'object' && !config.connector.name)
config.connector.name = name;
}
return registry.createDataSource(config);
}
在第一次运行dataSourcesFromConfig时,db(sqlite)初始化正常,但在第二次运行时,我现在得到错误:
browser.bundle.js:93172 Uncaught TypeError: Cannot create data source "sqlite": fs.existsSync is not a function
为什么我遇到这个?你能帮我么。非常感谢。
答案 0 :(得分:0)
您必须要求连接器,否则browserify不知道它需要包含在最终捆绑包中。以编程方式执行,您可以内联需要sqlite连接器,然后在要与sqlite一起使用的每个模型上使用attachTo。例如,在启动脚本中:
const DataSource = require("loopback-datasource.juggler").Datasource
module.exports = (app) => {
const local = new Datasource({
file_name:"dev.sqlite3",
location: "default",
name: "local",
connector: require("loopback-connector-cordova-sqlite")
})
app.models["myModel"].attachTo(local)
}