与此回复相关:https://github.com/wycats/handlebars.js/issues/476 您不能在 Handlebars 模板上分配新变量,您必须在模板数据上创建此对象 {name: 'steve', age: '40'}。
data.user = {name: 'steve', age: '40'}
在 .hbs 上
{{> myPartial user}}
不过你可以看看private variables:http://handlebarsjs.com/block_helpers.html
---- 2017 年 8 月更新 ----
使用新的 let 块辅助指令,您可以创建 HTML 变量以更轻松地操作您的显示逻辑:
全球 JS
// Create a new Global helper, available everywhere
Template.registerHelper('getUser', function () {
return Meteor.user()
})
Blaze HTML
使用全局帮助器将用户检索到变量中并将其用于 HTML
{{#let user=getUser}}
{{#if user}}
Hi {{user.name}}
{{else}}
Please Login
{{/if}}
{{/let}}
---- 2019 年更新 ----
让我们重新打开这个问题并将其放到下一个级别。
通过注册新的简单助手,您将能够直接从 Blaze 创建对象或数组(所以您想要的一切):
Template.registerHelper('object', function({hash}) {
return hash;
})
Template.registerHelper('array', function() {
return Array.from(arguments).slice(0, arguments.length-1)
})
用法:
{{> myPartial (object name="steve" age=40 array_example=(array true 2 "3"))}}
将作为上下文发送:
{
name: 'steve',
age: 40,
array_example: [true, 2, "3"]
}