我在管理仪表板中创建了一个事件创建者,一切正常,但现在我需要插入一个新字段:

info: Object

在我的HTML事件创建者中,我有以下选择:
<label for="info">Information Type:</label>
<select id="info" name="info">
 <option>Normal</option>
 <option>Special</option>
</select>

/create上发表文章
当这个事件到达我的控制器时,我需要将所有的表单输入保存到我的数据库中,很好,这个部分是100%工作的。
但是,在进行保存之前,我使用以下代码将select选项与数据库中info字段的实际值绑定:
event.pre('save', function(next) {
 if (this.info === 'Normal') {
   this.info = ['this text', 'is one text, but i want show as a list', 'that's why i am doing this']
 } else if (this.info === 'Special') {
   this.info = ['same', 'happens', 'here']
 }
});

我想知道这是否正确,是否有效,但对我来说似乎是错的。
例如,如果我选择“normal”,将显示如下:
<ul>
  <li>This text</li>
  <li>is one text, but i want show as a list</li>
  <li>that's why i am doing this</li>
</ul>

我想知道整件事是否正确,如果不正确,怎么做才对。如果可能的话,我还希望选择只使用html,而不使用预保存。
提前谢谢。

最佳答案

如果info字段的值是恒定的,我认为您的解决方案是最好的。
但是如果您需要对info字段使用动态值,您可以像这里一样更改代码;
http://jsfiddle.net/oprz2p2e/
如果表单上有很多字段,可以使用jquery$("#yourFormId").serialize()方法收集数据。
注:我想你知道如何使用ejs显示这些数据。您可以使用foreach-together ejs列出info字段值。

10-04 22:09
查看更多