doubi3929 2018-05-25 11:23
浏览 1229
已采纳

根据jQuery中的单选按钮选择显示和隐藏内容

I am trying to display different contents base on radio button select in jquery.

My HTML is something like this:

<div class="col-sm-5">
  <label class="radio-inline">
    <input type="radio" name="b_type" value="1" <?=(isset($type) && $type == 'Person') ?  ' checked' : ''?>> Person
  </label>
  <label class="radio-inline">
    <input type="radio" name="b_type" value="2" <?=(isset($type) && $type == 'Institute') ?  ' checked' : ''?>> Institute
  </label>
</div>

This is how I tried in jquery to display two different contents for each radio button selection.

$('input[type="radio"][name="b_type"]').on('change',function(){
  var sel = $(this);
  if(sel.val() == 1){
    $('#person-block').show();
    $('#person-institute').show();
  }else{
    $('#institute-block').show();
    $('#person-block').hide();
});

This code is working in some way. But there is a problem. Default radio button checked is dynamic. Lets assume second button is checked when the page is loading, then it display #persion-block contents. But I want to display #institute-block contents.

If I click on first button and then click on second its working.

Can anybody tell me how to figure this out? Thank you.

  • 写回答

6条回答 默认 最新

  • dth54864 2018-05-25 11:43
    关注

    Just trigger the change event in the element inside the document.ready

    Note : You have some id typo .

    $('input[type="radio"][name="b_type"]').on('change',function(){
    alert($(this).val());
      if($(this).val() == "1"){
        $('#person-block').show();
        $('#institute-block').hide();
      }else{
        $('#institute-block').show();
        $('#person-block').hide();
        }
    });
    
    $(document).ready(function(){
    $('input[type="radio"][name="b_type"]:checked').change();
    
    });
    <script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
    <div class="col-sm-5">
      <label class="radio-inline">
        <input type="radio" name="b_type" value="1" > Person
      </label>
      <label class="radio-inline">
        <input type="radio" name="b_type" value="2" checked> Institute
      </label>
    </div>
    <div id="person-block" >
      Person
    </div>
    <div id="institute-block" >
      Institute
    </div>

    </div>
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(5条)

报告相同问题?

悬赏问题

  • ¥15 乌班图ip地址配置及远程SSH
  • ¥15 怎么让点阵屏显示静态爱心,用keiluVision5写出让点阵屏显示静态爱心的代码,越快越好
  • ¥15 PSPICE制作一个加法器
  • ¥15 javaweb项目无法正常跳转
  • ¥15 VMBox虚拟机无法访问
  • ¥15 skd显示找不到头文件
  • ¥15 机器视觉中图片中长度与真实长度的关系
  • ¥15 fastreport table 怎么只让每页的最下面和最顶部有横线
  • ¥15 R语言卸载之后无法重装,显示电脑存在下载某些较大二进制文件行为,怎么办
  • ¥15 java 的protected权限 ,问题在注释里