使用cordova s​​qlite进行环回脱机同步

时间:2017-04-02 00:13:52

标签: node.js sqlite cordova loopbackjs

我正在创建一个使用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

为什么我遇到这个?你能帮我么。非常感谢。

1 个答案:

答案 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)
}