发布
社区首页 >问答首页 >在电子应用上使用LowDB

在电子应用上使用LowDB
EN

Stack Overflow用户
提问于 2016-04-18 16:13:29
回答 1查看 2.5K关注 0票数 0

我正在开发一个基本的应用程序与电子和AngularJS。为此,我使用电子样板(https://github.com/szwacz/electron-boilerplate),对于数据库,我使用LowDB(https://github.com/typicode/lowdb)。

我已经能够创建一个数据库(JSON)并从脚本中读取它。但我的问题是当我想要更新和保存。我可以更新,并且更改反映在JSON文件上,但是当我再次启动应用程序时,JSON具有与开始时相同的数据(它被覆盖)。

我认为这是电子样板的构建任务的一个问题,它总是覆盖文件。我以为当我完成发布应用程序的任务时,它会修复(Npm run release),但不会,它会覆盖json。

我正在加载数据库,因此:

代码语言:javascript
代码运行次数:0
复制
import low from 'lowdb';
import storage from 'lowdb/file-sync';
import {
    remote
}
from 'electron';
var fs = require('fs');

var app = remote.require('app');

const db = low(__dirname + '/db.json', {
    storage
});

document.addEventListener('DOMContentLoaded', function() {

db('users').push({
    'name': 'foo'
});

});

这个脚本是在开始时加载的,所以每次启动应用程序时,它都应该添加一个新条目。脚本在JSON文件中写入新条目,但是当启动重新启动时,JSON返回到以前的状态。

最后,我使用了localStorage,但我想使用LowDB将数据保存在本地。

下面是我之前评论过的关于app构建的任务(gulp文件):

代码语言:javascript
代码运行次数:0
复制
'use strict';

var pathUtil = require('path');
var Q = require('q');
var gulp = require('gulp');
var sass = require('gulp-sass');
var watch = require('gulp-watch');
var batch = require('gulp-batch');
var plumber = require('gulp-plumber');
var jetpack = require('fs-jetpack');

var bundle = require('./bundle');
var generateSpecImportsFile = require('./generate_spec_imports');
var utils = require('../utils');

var projectDir = jetpack;
var srcDir = projectDir.cwd('./app');
var destDir = projectDir.cwd('./build');

var paths = {
    copyFromAppDir: [
        './node_modules/**',
        './bower_components/**',
        './components/**',
        './scripts/**',
        './shared.services/**',
        './sections/**',
        './helpers/**',
        './db.json',
        './**/*.html',
        './**/*.+(jpg|png|svg|eot|ttf|woff|woff2)'
    ],
}

// -------------------------------------
// Tasks
// -------------------------------------

gulp.task('sass', ['clean'], function() {
    console.log('Compiling SASS...');
    gulp.src('app/styles/scss/main.scss')
        .pipe(sass().on('error', sass.logError))
        .pipe(gulp.dest(destDir.path('styles')));
});

gulp.task('watch:sass', function() {
    console.log('Watching SASS...');
    var sassWatcher = gulp.watch(['app/styles/scss/*.scss','app/**/**/*.scss'], ['sass']);

    sassWatcher.on('change', function(event) {
        console.log('File ' + event.path + ' was ' + event.type + ', running tasks...');
    });
gulp.src('app/styles/scss/main.scss')
        .pipe(sass().on('error', sass.logError))
        .pipe(gulp.dest(destDir.path('styles')));
});


gulp.task('clean', function (callback) {
    return destDir.dirAsync('.', { empty: true });
});


var copyTask = function () {
    return projectDir.copyAsync('app', destDir.path(), {
            overwrite: true,
            matching: paths.copyFromAppDir
        });
};
gulp.task('copy', ['clean'], copyTask);
gulp.task('copy-watch', copyTask);


var bundleApplication = function () {
    return Q.all([
            bundle(srcDir.path('background.js'), destDir.path('background.js')),
            bundle(srcDir.path('app.js'), destDir.path('app.js')),
            bundle(srcDir.path('script.js'), destDir.path('script.js')),
        ]);
};

var bundleSpecs = function () {
    return generateSpecImportsFile().then(function (specEntryPointPath) {
        return bundle(specEntryPointPath, destDir.path('spec.js'));
    });
};

var bundleTask = function () {
    if (utils.getEnvName() === 'test') {
        return bundleSpecs();
    }
    return bundleApplication();
};
gulp.task('bundle', ['clean'], bundleTask);
gulp.task('bundle-watch', bundleTask);




gulp.task('finalize', ['clean'], function () {
    var manifest = srcDir.read('package.json', 'json');

    // Add "dev" or "test" suffix to name, so Electron will write all data
    // like cookies and localStorage in separate places for each environment.
    switch (utils.getEnvName()) {
        case 'development':
            manifest.name += '-dev';
            manifest.productName += ' Dev';
            break;
        case 'test':
            manifest.name += '-test';
            manifest.productName += ' Test';
            break;
    }

    // Copy environment variables to package.json file for easy use
    // in the running application. This is not official way of doing
    // things, but also isn't prohibited ;)
    manifest.env = projectDir.read('config/env_' + utils.getEnvName() + '.json', 'json');

    destDir.write('package.json', manifest);
});


gulp.task('watch', function () {
    watch('app/**/*.js', batch(function (events, done) {
        gulp.start('bundle-watch', done);
    }));
    watch(paths.copyFromAppDir, { cwd: 'app' }, batch(function (events, done) {
        gulp.start('copy-watch', done);
    }));
    watch('app/**/scss/*.scss', batch(function (events, done) {
        gulp.start('watch:sass', done);
    }));
    watch('app/**/**/*.scss', batch(function (events, done) {
        gulp.start('watch:sass');
    }));
});


gulp.task('build', ['bundle', 'sass', 'copy', 'finalize']);

你怎么看,在'copyFromAppDir‘里面有一个db.json。这个文件是我的数据库,但我想要更新它,并且更改会持续存在,但我无法做到这一点。

致以亲切的问候!

EN

回答 1

Stack Overflow用户

发布于 2016-04-19 23:52:17

看起来你的吞咽任务“清理”正在覆盖你的db.json文件。因为您使用的是lowDB,所以这等同于覆盖您的数据库。如果从'copyFromAppDir‘数组中删除行'./db.json',,则更改应该保留下来。

如下所示:

代码语言:javascript
代码运行次数:0
复制
var paths = {
    copyFromAppDir: [
        './node_modules/**',
        './bower_components/**',
        './components/**',
        './scripts/**',
        './shared.services/**',
        './sections/**',
        './helpers/**',
        './**/*.html',
        './**/*.+(jpg|png|svg|eot|ttf|woff|woff2)'
    ],
}
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/36688595

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档