繁体   English   中英

用于更新的SimpleSchema中的autoValue未设置给定值

[英]autoValue in SimpleSchema for update does not set given value

我在SimpleSchema中使用以下字段,

  "fileNo": {
    type: String,
    label: "File No.",
    autoValue: function() {
      console.log('this', this);
      console.log('typeof this.value.length ', typeof this.value.length);
      console.log('this.value.length ', this.value.length, this.value.length === 0, this.value.length == 0);
      console.log('this.value ', this.value, typeof this.value);
      console.log('this.operator ', this.operator);
      console.log('this.isSet ', this.isSet);
            if ( this.isSet && 0 === this.value.length ) {
                console.log('if part ran.');
                return "-";
            } else {
              console.log('else part ran.');
            }
        },
    optional:true
  },

我正在使用autoform update字段。 问题是当我使用空字符串更新字段(即,保持文本框为空)时 ,未根据上面的SimpleSchema代码中的字段定义设置值-

我得到如下日志

clients.js:79 this {isSet: true, value: "", operator: "$unset", unset: ƒ, field: ƒ, …}
clients.js:80 typeof this.value.length  number
clients.js:81 this.value.length  0 true true
clients.js:82 this.value   string
clients.js:83 this.operator  $unset
clients.js:84 this.isSet  true
clients.js:86 if part ran.
clients.js:79 this {isSet: true, value: "-", operator: "$unset", unset: ƒ, field: ƒ, …}
clients.js:80 typeof this.value.length  number
clients.js:81 this.value.length  1 false false
clients.js:82 this.value  - string
clients.js:83 this.operator  $unset
clients.js:84 this.isSet  true
clients.js:89 else part ran.    

我的收款文件没有栏位fileNo

我想念什么? 我想要的就是fileNo值为empty/undefined值必须设置为- (连字符) 在文档中,它必须类似于fileNo : "-"

您应该处理两种情况:

  1. 文件insert用空(未定义) value用于fileNo

  2. 使用fileNovalue update文档。

在第二种情况下,如果其值为空字符串( optional: true ),验证器将尝试从文档中删除该字段。 我们可以抓住并防止这种情况。

  fileNo: {
    type: String,
    label: 'File No.',
    autoValue() {
      if (this.isInsert && (this.value == null || !this.value.length)) {
        return '-';
      }
      if (this.isUpdate && this.isSet && this.operator === '$unset') {
        return { $set: '-' };
      }
    },
    optional: true
  }

补充 :用于编写此答案的文档(代码按预期工作;在本地测试):

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM