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 python:excel数据写入多个对应word文档
  • ¥60 全一数分解素因子和素数循环节位数
  • ¥15 ffmpeg如何安装到虚拟环境
  • ¥188 寻找能做王者评分提取的
  • ¥15 matlab用simulink求解一个二阶微分方程,要求截图
  • ¥30 乘子法解约束最优化问题的matlab代码文件,最好有matlab代码文件
  • ¥15 写论文,需要数据支撑
  • ¥15 identifier of an instance of 类 was altered from xx to xx错误
  • ¥100 反编译微信小游戏求指导
  • ¥15 docker模式webrtc-streamer 无法播放公网rtsp