Jquery根据单选按钮值选择

时间:2014-03-26 14:54:28

标签: jquery jquery-selectors radio-button

我已经查看了大约10个类似的问题,但还没有找到解决方案。我不确定我的问题是否在选择器中,我正在测试"如果"或者我尝试显示/隐藏字段的方式。

我想隐藏输入名称=" wpbpp_settings [slideshowSpeed]"如果单选按钮名称的值=" wpbpp_settings [slideshow]"是" false"

这是我的表格:

<div class="wrap">
    <h2>WP Blossom PuckPros Theme Options</h2>

    <form method="post" action="options.php">

        <?php settings_fields('wpbpp_settings_group'); ?>

        <h4><?php _e('Excerpt Length for Wide Page Slider', 'wpbpp_domain'); ?></h4>
        <p>
            <label class="description" for="wpbpp_settings[excerpt_length]"><?php _e('Enter the excerpt length (number of words)', 'wpbpp_domain'); ?></label>
            <input id="wpbpp_settings[excerpt_length]" name="wpbpp_settings[excerpt_length]" type="number" min="20" max="55" step="1" value="<?php echo $wpbpp_options['excerpt_length']; ?>"/>
        </p>

        <h4><?php _e('Settings for Wide Slider', 'wpbpp_domain'); ?></h4>

        <?php
           if (!isset($wpbpp_options['slideshow'])) {

           $wpbpp_options['slideshow']='false';
               }

        ?>

        <p>
            <label class="description" for="wpbpp_settings[slideshow]"><?php _e('Do you want the slider to advance automatically?', 'wpbpp_domain'); ?></label>
            <input id="wpbpp_settings[slideshow]1" name="wpbpp_settings[slideshow]" type="radio" <?php if($wpbpp_options['slideshow'] == 'true') echo 'checked="checked"'; ?> value="true" />Yes
            <input id="wpbpp_settings[slideshow]2" name="wpbpp_settings[slideshow]" type="radio" <?php if($wpbpp_options['slideshow'] == 'false') echo 'checked="checked"'; ?> value="false" />No

         </p>
         <p>   
            <label class="description" for="wpbpp_settings[slideshowSpeed]"><?php _e('How often do you want the slider to advance (number of seconds)?', 'wpbpp_domain'); ?></label>
            <input id="wpbpp_settings[slideshowSpeed]" name="wpbpp_settings[slideshowSpeed]" type="number" min="1" max="8" step="1" value="<?php echo $wpbpp_options['slideshowSpeed']; ?>"/>
        </p>

        <p class="submit">
            <input type="submit" class="button-primary" value="<?php _e('Save Options', 'wpbpp_domain'); ?>" />
        </p>

    </form>

</div>

和我的jquery:

<script  type="text/javascript">

jQuery(document).ready(function($) {

  togglefields();

  $('input:radio[name="wpbpp_settings[slideshow]"]').val().change(function() { togglefields(); });
});   


  function togglefields() { 
   if ($('input:radio[name="wpbpp_settings[slideshow]"].prop("checked", true)').val() =="true") {
      $('input:radio[name="wpbpp_settings[slideshowSpeed]"]').show();
    } else {
       $('input:radio[name="wpbpp_settings[slideshowSpeed]"]').hide();
    }   

</script>

__ _ __ _ _ 编辑 _ __ _ __ _ __ _ ____

所以现在我已经接近了。我的问题是我的&#34; if&#34;声明始终评估为&#34; true&#34;。

这是修订后的jquery:

<script  type="text/javascript">

jQuery(document).ready(function($) {

  togglefields();

  $('input[name="wpbpp_settings[slideshow]"]').change(function(){ togglefields() });

});   

  function togglefields() { 
   if (jQuery('input[name="wpbpp_settings[slideshow]"]').val() =="true") {
      jQuery('input[name="wpbpp_settings[slideshowSpeed]"]').show();
      alert ('show');
    } else {
       jQuery('input[name="wpbpp_settings[slideshowSpeed]"]').hide();
       alert ('hide');

    }   
   }
</script>

2 个答案:

答案 0 :(得分:0)

您正在寻找单选按钮的已检查属性。 .val()没有抓住你。

而是检查属性

// This would give you info whether the radio is checked or not
  if (jQuery('input[name="wpbpp_settings[slideshow]"]').is(':checked')) {

答案 1 :(得分:0)

尝试将jQuery('input[name="wpbpp_settings[slideshow]"]').val()记录到控制台中。看看你是否做了正确的比较。你的方法应该是:

  1. 选择包含name="wpbpp_settings[slideshow]"
  2. 的单选按钮组
  3. 找到该组的选中按钮
  4. 找到它的价值
  5. 比较并做任何你想要的事情

    var selectedButton=$("input[name='wpbpp_settings[slideshow]']"]:checked"); var value = selectedButton.val();

  6. 甚至是,

    var selectedValue = $("input[name='wpbpp_settings[slideshow]']"]:checked").val();
    

    查看selectedValue中的内容,然后进行进一步比较。