Bookshelf.js设置属性不在数据库中

时间:2015-04-03 03:21:37

标签: javascript node.js bookshelf.js

我有一个Bookshelf.js模型。我希望能够为此模型设置和获取在数据库中不持久的属性。

例如,假设我有一个看起来像这样的模型:

var Domain = bookshelf.Model.extend({
      tableName: 'domains',
      initialize: function() {
        this.on('creating', this.setDomainName);
      },
      setDomainName: function() {
        this.set('name', getDomainFromUrl(this.url));
      }
    });

使用如下所示的架构:

knex.schema.createTable('domains', function (table) {
    table.increments().index();
    table.text('name').index();
    table.timestamps();
  });

我希望能够保存名为url的属性,然后在保存之前将url解析为域。

当我尝试这样的事情时:

new Domain({url: 'http://someurl.com/foo/bar'}).save()

我收到错误消息:

"column \"url\" of relation \"domains\" does not exist"

我看了看。我找不到任何方法来将非持久性属性添加到bookshelf.js模型中。我也找不到有关向bookshelf.js模型添加自定义getter和setter方法的任何信息。

感谢任何帮助或见解!

1 个答案:

答案 0 :(得分:6)

在我的手机上,原谅简短的回复,但你想要的是什么叫做虚拟'或者'复合'字段。

https://github.com/tgriesser/bookshelf/wiki/Plugin:-Virtuals

每个数据库映射器都有它们,但是当您不知道它们所称的内容时,可以理解的是难以谷歌解决方案。