繁体   English   中英

通过_ids数组从集合中删除mongodb文档

[英]Remove mongodb documents from a collection by an array of _ids

使用Meteor,我有一个联系人集合,其中列出了每个联系人旁边的复选框。

我希望能够选择多个复选框,然后单击一个按钮以从“联系人”集合中删除所选的联系人。

使用下面的代码,选定的_ids将显示在控制台的数组中,但不会删除任何内容,也不会产生错误。

contact.html

<template name="contacts">
    <h1>Contacts</h1>
    <ul>
      {{#each contacts}}
        {{> contact}}
      {{/each}}
    </ul>
    <br/>
    <a href="{{pathFor route='create_contact'}}">Create Contact</a>
    <a class="delete-selected" href="">Delete Selected Contacts</a>
</template>

contact.html

<template name="contact">
  <li style="list-style:none;">
    <input id="{{_id}}" type="checkbox" value="{{_id}}" name="contact"/>
    <a href="{{pathFor 'contact.show'}}"><span class="contact">{{firstName}} {{lastName}} <strong>{{company}}</strong></span></a> {{#if contactType}}({{contactType}}){{/if}}
  </li>
</template>

客户JS

Template.contacts.events = {
  'click .delete-selected': function(e) {
  e.preventDefault();

  var selectedContacts = [];
  $('input[name=contact]:checked').each(function() {
    selectedContacts.push($(this).val());
  });
  Meteor.call('removeSelectedContacts', {selectedContacts: selectedContacts});
}

服务器JS

Meteor.methods({
    removeSelectedContacts: function(selectedContacts) {
        Contacts.remove({_id:{$in:[selectedContacts]}})
        //Contacts.remove({selectedContacts});
        console.log(selectedContacts);
    }
});

谢谢

@corvid:我认为您一次只能在客户端上删除一个(通过_id

@serks:您在那里有一个额外的数组级别,在您的方法中只需执行以下操作:

Contacts.remove({ _id: { $in: selectedContacts }});

调用方法的方式也存在错误,而不是:

Meteor.call('removeSelectedContacts', {selectedContacts: selectedContacts});

只需直接传递参数:

Meteor.call('removeSelectedContacts',selectedContacts);

该方法需要一个数组,而不是对象。

使用$in运算符。

Template.contacts.events({
  'submit #delete-contacts-form': function (e, template) {
    // assumes permissions are set on server appropriately.
    Contacts.remove({
      _id: {
        $in: $(e.target).find('input:checked').map(el => el.val())  // assumes the value of each checkbox is the _id
      }
    });
  }
});

暂无
暂无

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

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