我的表单中有一个下拉列表,需要在选择“其他”时呈现新的文本输入。我试图用以下方法做到这一点无济于事:
Rails查看
<div class ="testinputs"
<li><%= o.input :name, :as => :select, :collection => [:Anniversary, :Birthday, :Graduation, :Holiday, :'Mothers day', :'Fathers day', :'Valentines day', :Wedding, :other ]%></li>
<%= o.input :name, :as => :hidden %>
</div>
jquery的
$(function() {
$("#testinputs").change(function() {
var val = $(this).val();
if(val == 'other') {
$('input[name="occasion[name]"]').show();
} else {
$('input[name="occasion[name]"]').hide();
}
}).change();
});
我的表单呈现 HTML :
<div class="testinputs" <li=""><div class="control-group select required"><label class="select required control-label" for="occasion_name"><abbr title="required">*</abbr> Name</label><div class="controls"><select class="select required" id="occasion_name" name="occasion[name]"><option value=""></option>
<option value="Valentines day">Valentines day</option>
<option value="Wedding">Wedding</option>
<option value="other">other</option></select></div></div>
<div class="control-group hidden"><div class="controls"><input class="hidden" id="occasion_name" name="occasion[name]" type="hidden"></div></div>
</div>
答案 0 :(得分:3)
我相信您将输入呈现为type =“hidden”,这意味着当您通过JS显示它时,它将无法显示。
使用普通文本输入,通过css / js隐藏它然后显示它。