微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

Meteor Blaze 助手和 Mongo collection.find 与会话键选择器

如何解决Meteor Blaze 助手和 Mongo collection.find 与会话键选择器

这个 Meteor 代码使用 Meteor Blaze 模板助手,它为一些 html 元素提供来自 mongo 集合的数据。

collection.findOneSession.get 作为选择器,因此当 Session 键没有值时,我会得到一个空对象到模板,这样我就不会得到任何数据,即空白元素。但我仍然在某些元素中获得值。主要是 html 文件中注释的可编辑 divspan 以及一个 input 元素。

我哪里做错了? 当我通过设置 Session.set('plate','') 触发事件时,我试图清理“表单”,即会话键“plate”的空白值,空对象,Blaze 模板没有数据,清除元素,对吗? 谢谢

//client/main.js

Meteor.startup(function(){
  listenToEvents()
})

///// globle listener /////
function listenToEvents(){
  $('.new').on('click',function(e){
    let elementId = $(this).parents('div')[2].id 
    if(elementId == 'vehicle'){
      Session.set('plate','') //<<< used in mongo collection selector
    }
  })
}


///// Blaze helper /////
Template.vehicle.helpers({
  'vehicle' : function(){
    if(Session.get('plate') == undefined){
      console.log('no plate selected')
      return
    }
    let searchForPlate = { "$regex" : Session.get('plate'),"$options" : "i"} // set to '' by event above 
    let vehicle = Vehicles.findOne({'plate': searchForPlate})

    if(!vehicle){ 
      console.log('empty vehicle object')
      return {}
    }
    console.log('vehcile selected: ',vehicle)
    
    if(vehicle.vin.length == 17){ 
      vehicle.vin_a = vehicle.vin.substr(0,9)
    }
    vehicle.remain = Math.round(diff)
    if(diff <= 0) vehicle.expired = true
 
    return vehicle
  }
})
<template name="vehicle">
  <div id="vehicle" class="subject-container" >

    <div class="section-head">
      <div class="control">
        <button class="toggle">-</button>
        <button class="new">N</button>
      </div>
      <div>
      <!-- the next input does not get cleared -->
        <input id="plate" type="text" size="6" placeholder="plate" value={{vehicle.plate}}>
        
        <!-- the next span does not get cleared -->
        <span data-expired={{vehicle.expired}}>{{vehicle.remain}} {{vehicle.expiry}}</span>
      </div>
    </div>
    
    <div class="body">
      <!-- the next div does not get cleared -->
      <div id="vin" class="editable" contenteditable="true">{{vehicle.vin_a}}<span id="vinb">{{vehicle.vin_b}}</span><span id="vin4">{{vehicle.vin4}}</span></div>
      <input type="text" placeholder="YR,make,modle" value={{vehicle.info}}>
    </div>
  </div>
</template>

解决方法

嗯,不,一个空的正则表达式匹配一切。如果您打开 mongo shell 并针对任何包含内容的集合运行类似的查询,这很容易测试:

rs0:PRIMARY> db.users.find({_id: {$regex: ''}}).count()
2723

我只是明确地防止这种情况,你可以很容易地这样做:

    if (!Session.get('plate')){
      console.log('no plate selected')
      return
    }

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。