流星助手检查平等
Meteor Helper Check equality
有没有办法在 meteor helper 中检查字符串的值?
假设我有这个帮手
Template.example.helpers({
typeOfVideo:function(videoType){
var videoLink = GS.Gems.Collections.Gems.findOne({_id:this._id}).videoLink;
if(videoLink.match(/youtube\.com/)){
return "youtube";
}else if(videoLink.match(/vimeo\.com/)){
return "vimeo";
}else{
return "undefined"
}
}
})
现在我想检查视频是否等于 Youtube、Vimeo 或未定义,我可以通过返回 true/false 来完成,但由于还有更多我想知道我处理的是什么类型的视频
已经尝试
{{#if typeOfVideo=youtube}} <!-- also {{#if typeOfVideo 'youtube'}}
youtube
{{/if}}
{{#if typeOfVideo=vimeo}}
vimeo
{{/if}}
模板呈现所有值(youtube、vimeo),我缺少什么?
由于 Spacebars(Meteor 模板系统)是一个“无逻辑”模板系统(类似于它所基于的 Handlebars),您不能直接检查 if
语句中的相等性。
但是您可以创建一个带有两个参数的 global helper 来检查字符串相等性或匹配字符串,如下所示:
Template.registerHelper('isEqual', function(string, target) {
if( string.match( new RegExp(target, 'g') ) ) {
return true;
}
return false;
});
并像这样在您的模板中使用它:
{{#if isEqual videoLink 'youtube'}}
<p>Youtube</p>
{{else}}
<p>Vimeo</p>
{{/if}}
空格键里没有else if
,如果你有很多情况要查的话可能会比较麻烦。
但是你可以考虑在可能的情况下直接从全局助手中注入 template/content。
有没有办法在 meteor helper 中检查字符串的值?
假设我有这个帮手
Template.example.helpers({
typeOfVideo:function(videoType){
var videoLink = GS.Gems.Collections.Gems.findOne({_id:this._id}).videoLink;
if(videoLink.match(/youtube\.com/)){
return "youtube";
}else if(videoLink.match(/vimeo\.com/)){
return "vimeo";
}else{
return "undefined"
}
}
})
现在我想检查视频是否等于 Youtube、Vimeo 或未定义,我可以通过返回 true/false 来完成,但由于还有更多我想知道我处理的是什么类型的视频
已经尝试
{{#if typeOfVideo=youtube}} <!-- also {{#if typeOfVideo 'youtube'}}
youtube
{{/if}}
{{#if typeOfVideo=vimeo}}
vimeo
{{/if}}
模板呈现所有值(youtube、vimeo),我缺少什么?
由于 Spacebars(Meteor 模板系统)是一个“无逻辑”模板系统(类似于它所基于的 Handlebars),您不能直接检查 if
语句中的相等性。
但是您可以创建一个带有两个参数的 global helper 来检查字符串相等性或匹配字符串,如下所示:
Template.registerHelper('isEqual', function(string, target) {
if( string.match( new RegExp(target, 'g') ) ) {
return true;
}
return false;
});
并像这样在您的模板中使用它:
{{#if isEqual videoLink 'youtube'}}
<p>Youtube</p>
{{else}}
<p>Vimeo</p>
{{/if}}
空格键里没有else if
,如果你有很多情况要查的话可能会比较麻烦。
但是你可以考虑在可能的情况下直接从全局助手中注入 template/content。