0

我试图让下面的代码在 WordPress 中工作,但我无法让它工作。表单显示正确,但选择不同的选项无济于事。我不知道如何让 jQuery 工作。代码本身确实有效。在此先感谢您的帮助!

<style type="text/css">
.hide {
     display: none;
}
</style>
<script type="text/javascript" src="files/jquery-1.8.1.js"></script>
<script type="text/javascript">
var $j = jQuery.noConflict();

$j("#choices").change(function(){
   $j('.hide').slideUp();
   $j('#'+this.value).slideDown()
});
</script>
<form>
<select id="choices">
        <option value="none">Select an option...</option>
    <option value="option1">Option 1</option>
    <option value="option2">Option 2</option>
    <option value="option3">Option 3</option>
        <option value="option4">Option 4</option>
        <option value="option5">Option 5</option>
        <option value="option6">Option 6</option>
        <option value="option7">Option 7</option>
</select>
</form>
<div id="option1" class="hide">Option 1 TEXT</div>
<div id="option2" class="hide">Option 2 TEXT</div>
<div id="option3" class="hide">Option 3 TEXT</div>
<div id="option4" class="hide">Option 4 TEXT</div>
<div id="option5" class="hide">Option 5 TEXT</div>
<div id="option6" class="hide">Option 6 TEXT</div>
<div id="option7" class="hide">Option 7 TEXT</div>
4

3 回答 3

2

两个流行的警告。

  • 执行脚本时 DOM 尚未准备好

    var $j = jQuery.noConflict();
    $j(document).ready(function(){
     $j("#choices").change(function(){
        $j('.hide').slideUp();
        $j('#'+this.value).slideDown()
     });
    })
    
  • 您的 ID 可能会被使用两次。将 ID 更改为 HTML 和 JS 中的类。检查与

    console.log( $j("#choices") )
    
于 2012-09-15T19:05:09.903 回答
1

试试这个:

<script type="text/javascript">
    var $j = jQuery.noConflict();

    $j(document).ready(function() {
        $j("#choices").change(function(){
           $j('.hide').slideUp();
           $j('#'+this.value).slideDown()
        });
    });
</script>

这将确保 jQuery 代码在 DOM 准备好之前不会执行。

于 2012-09-15T19:05:01.997 回答