Как установить выбранное значение в выпадающем списке с помощью Mustache.js?
Можно ли это сделать с помощью Mustache.js?
var data = {"val":"3"},
template = '<select>' +
'<option value="1">1</option>' +
'<option value="2">2</option>' +
'<option value="3">3</option>' +
'</select>';
var html = Mustache.to_html(template, data);
$(html).appendTo('body');
Ответы
Ответ 1
Атрибут val
не работает, потому что <select>
берет свое значение из <option>
, у которого есть атрибут selected
. Я не очень знаком с Усы, но это должно работать:
// snip...
var html = Mustache.to_html(template, data);
$(html)
.find('option[value=3]').attr('selected', true)
.end().appendTo('body');
Я думаю, что шаблон, который вы используете, не является идиоматическим Mustache — он слишком грубый; вы на самом деле ничего не замаскируете. Что-то вроде этого может быть больше Mustache-y:
var template = '<select>{{#options}}' +
'<option value="{{val}}" {{#sel}}selected{{/sel}}>' +
'{{txt}}' +
'</option>' +
'{{/options}}</select>',
data = {options: [
{val: 1, txt: 'uno'},
{val: 2, txt: 'dos'},
{val: 3, txt: 'tres', sel: true}
]};
var html = Mustache.to_html(template, data);
$(html).appendTo('body');
Demo →
Ответ 2
если вы не хотите изменять массив или дерево DOM, вы можете использовать функцию:
var selval=3; // select 3
var template = '<select>{{#options}}' +
'<option value="{{val}}" {{selected}}>{{txt}}</option>' +
'{{/options}}</select>';
var data={
options: [
{val: 1, txt: 'one'},
{val: 2, txt: 'two'},
{val: 3, txt: 'three'}
],
selected: function() {
if (this.val==selval) return "selected";
return "";
}
};
var html = Mustache.to_html(template, data);
Ответ 3
Я немного опоздал, я знаю, только для справок в будущем:
<script>
var templates = {
'dropbox': '{{#options}}{{>option}}{{/options}}',
'option': '<option value="{{value}}"{{#selected}} selected="selected"{{/selected}}>{{text}}</option>'
};
var data = {
'options': [
{ 'value': '1', 'text': 'One' },
{ 'value': '2', 'text': 'Two', 'selected': true },
{ 'value': '3', 'text': 'Three' }
]
};
$('#number').append(Mustache.render(templates.dropbox, data, templates));
</script>
<select id='number' name='number'>
<option value="0">Choose a number</option>
</select>
Ответ 4
Я использую этот хак для упрощения:
buildOptions = function(object) {
for (var i in object) {
object[i + '=' + object[i]] = true;
}
return object;
}
Таким образом, вы можете преобразовать данные такого рода:
{
field1: 'abc',
field2: 'xyz'
}
С таким шаблоном усов:
<select name="field1">
<option {{#field1=abc}}selected{{/field1=abc}}>abc</option>
<option {{#field1=def}}selected{{/field1=def}}>def</option>
<option {{#field1=ghi}}selected{{/field1=ghi}}>ghi</option>
</select>
<select name="field2">
<option {{#field2=uvw}}selected{{/field2=uvw}}>uvw</option>
<option {{#field2=xyz}}selected{{/field2=xyz}}>xyz</option>
</select>
Вот так:
html = Mustache.to_html(template, buildOptions(data));
Что еще очень легко читать! Единственное предостережение в том, что у вас не может быть. в ваших значениях.