meteor - 如何在我的查询中重置我的 Session 以便再次显示整个集合?
问题描述
我的 MongoDB 查询结果受 Sessions 值的影响,例如recipientsDetails.find({ paymentStatus:{$in: Session.get('pendingFilter')} }).fetch();
这些pendingFilter Sessions值设置为启用过滤结果,从而仅需要集合中的特定值,例如仅显示:成功支付的交易、失败的交易或撤销的交易等。
默认情况下,pendingFilter
会话值是空的,所以当我的页面第一次加载时,整个集合(未过滤)显示,但是在我使用了各种过滤函数之后,现在想要返回整个集合未过滤的默认状态显示,这似乎失败了。有人可以帮助解释为什么这不起作用并提供解决方案吗?
下面是我的实际 MongoDB 查询的样子,然后是产量:
var userIdCode = Meteor.userId();
var phoneNumber = Meteor.users.findOne({_id: userIdCode }, { fields: { "profile.telephoneNumber": 1 } }, {sort: {paymentDate: -1 }} );
var usersPhoneNumber = phoneNumber.profile.telephoneNumber;
recipientsDetails.find({
paymentStatus:{
$in: Session.get('pendingFilter')
},
recipientPaymentStatus: {
$in: Session.get('pendingFilter')
}
},
{ $or: [ { payersNumber: usersPhoneNumber },
{ recipientNumber: usersPhoneNumber } ] },
{sort: {paymentDate: 'desc' }}).fetch();
上面的查询产生:
0:
payersName: "Sa Acea"
payersNumber: "+254705087633"
paymentDate: "2019-03-28 22:38:30"
paymentStatus: "Success"
recipientPaymentStatus: "Reversed"
recipientNumber: "+254705087633"
_id: "D3gY4BoR2tvxdK4xv"
1:
payersName: "Paul Acea"
payersNumber: "+254705557688"
paymentDate: "2019-03-28 22:38:30"
paymentStatus: "Pending"
recipientPaymentStatus: "Success"
recipientNumber: "+254705087633"
_id: "ajCjYbLaDP7x4iAFK"
2:
payersName: "Simon Bolton"
payersNumber: "+25470887633"
paymentDate: "2019-03-28 22:38:30"
paymentStatus: "Success"
recipientPaymentStatus: "Complete"
recipientNumber: "+254705087633"
_id: "K4d6wDrjRRdSyCkhW"
我有三个过滤器功能,单击时仅显示指定的集合值。如下图所示:
'click .reversedSubMenu' (event, instance) {
event.preventDefault();
Session.set('pendingFilter', [ "Success", "Reversed" ]);
},
这正确地产生:
0:
payersName: "Sabiti Asea"
payersNumber: "+254705087633"
paymentDate: "2019-03-28 22:38:30"
paymentStatus: "Success"
recipientPaymentStatus: "Reversed"
_id: "D3gY4BoR2tvxdK4xv"
.
'click .inPescrowSubMenu' (event, instance) {
event.preventDefault();
Session.set('pendingFilter', [ "Success", "Pending" ]);
},
这正确地产生:
0:
payersName: "Paul Asea"
payersNumber: "+254705557688"
paymentDate: "2019-03-28 22:38:30"
paymentStatus: "Pending"
recipientPaymentStatus: "Success"
_id: "ajCjYbLaDP7x4iAFK"
.
'click .paidSubMenu' (event, instance) {
event.preventDefault();
Session.set('pendingFilter', [ "Success", "Complete" ]);
},
这也正确地产生:
0:
payersName: "Simon Bolton"
payersNumber: "+25470887633"
paymentDate: "2019-03-28 22:38:30"
paymentStatus: "Success"
recipientPaymentStatus: "Complete"
_id: "K4d6wDrjRRdSyCkhW"
这里的问题是以下.reset
功能无法按设计运行。单击时,pendingFilter
会话将重置为 null,但我无法根据需要查看整个集合。
'click .reset' (event, instance) {
event.preventDefault();
Session.set('pendingFilter', []);
var testing = Session.get('pendingFilter');
console.log("Testing PendingFilter: " +testing )
},
以上在浏览器控制台中产生:Testing PendingFilter:
单击后所需的结果.reset
是 yield 显示整个/未过滤的集合,如下所示:
0:
payersName: "Sabiti Asea"
payersNumber: "+254705087633"
paymentDate: "2019-03-28 22:38:30"
paymentStatus: "Success"
recipientPaymentStatus: "Reversed"
recipientNumber: "+254705087633"
_id: "D3gY4BoR2tvxdK4xv"
1:
payersName: "Paul Asea"
payersNumber: "+254705557688"
paymentDate: "2019-03-28 22:38:30"
paymentStatus: "Pending"
recipientPaymentStatus: "Success"
recipientNumber: "+254705087633"
_id: "ajCjYbLaDP7x4iAFK"
2:
payersName: "Simon Bolton"
payersNumber: "+25470887633"
paymentDate: "2019-03-28 22:38:30"
paymentStatus: "Success"
recipientPaymentStatus: "Complete"
recipientNumber: "+254705087633"
_id: "K4d6wDrjRRdSyCkhW"
如何制定我的重置功能/或查询以启用上述所需的结果?
提前致谢
解决方案
我不知道为什么我之前没有弄清楚这一点,但我对RESET要做的就是简单地将所有数组值添加到会话中,如下所示:
'click .reset' (event, instance) {
event.preventDefault();
Session.set('pendingFilter', [ "Pending", "Complete", "Success", "Reversed" ]);
var testing = Session.get('pendingFilter');
console.log("Testing PendingFilter: " +testing )
},
推荐阅读
- sql-server - Datagridview 使用 SQL Server 显示没有数据 vb.net
- reactjs - 这是什么模式在 React 中使用箭头函数?
- go - Go libstd.so with errors on Alpine
- jasper-reports - How to get sum of the XML repeated element values from a list in report?
- spring-boot - Jhipster 无法在登录前使用匿名用户
- swift - Backslash in string from standard input, no way to stripe it
- typoscript - TYPO3 Dynamic Localized Label in TypoScript
- javascript - 使用 jquery 根据“父”ID 选择“子”
- docker - 从码头看不到本地蚊子
- sql - I get syntax error when I want to reset primary key of sqlite table