这些选择选项是通过wordpress后端以及以下div标签更改的。
我需要的是让相应的div 标签仅在选择框位于该选择上时显示它是什么数字子。
代码示例:
<form>
<select class="select" name="SELECT_Mood_30">
<option value="0"></option>
<option value="hap">Happy</option>
<option value="sad">Sadness</option>
<option value="ang">Angry</option>
<option value="gru">Grumpy</option>
</select>
</form>
<ul id="show-these">
<li></li>
<li>Happy huh?</li>
<li>Why so sad?</li>
<li>Everything will be ok!</li>
<li>Cheer up!</li>
</ul>
所以基本上我希望jquery能够知道选择了哪个数字孩子,并在li ID"show-these"中显示相同数字的孩子。
JS
var $ul = $('#show-these');
$ul.find('li').hide();
$('.select').on('change', function(){
var index = $(this).find('option:selected').index();
var $ul = $('#show-these');
$ul.find('li').hide();
$ul.find('li').eq(index).show();
});
.HTML
<div id="show-these">
<li></li>
<li>Happy huh?</li>
<li>Why so sad?</li>
<li>Everything will be ok!</li>
<li>Cheer up!</li>
</div>
检查小提琴
猜猜这会有所帮助:
<select class="select" onchange="update(this.value)" name="SELECT_Mood_30">
<option value="0"></option>
<option value="hap">Happy</option>
<option value="sad">Sadness</option>
<option value="ang">Angry</option>
<option value="gru">Grumpy</option>
</select>
<div id="show-these">
<li></li>
<li>Happy huh?</li>
<li>Why so sad?</li>
<li>Everything will be ok!</li>
<li>Cheer up!</li>
</div>
<script type="text/javascript">
function update(value){
var option = $('.select').find('option[value="'+value+'"]');
var index = $('.select').children().index(option);
$('#show-these').children().hide();
$($('#show-these').children()[index]).show();
}
</script>