JQuery函数不响应单选按钮

ker*_*sun 0 javascript php jquery function

这对我来说是一个非常棘手的问题(或者我只是非常愚蠢).尝试使用JQuery功能,当用户选择某个单选按钮时,下面的表单会相应更改(例如,个人看到姓名,公司,职位,电话,电子邮件和地址.公司只看到公司,电话,电子邮件和地址.但目前点击单选按钮无效.

我还想问:1)是我的函数$('#contactType> input').在正确的地方(在其中)还是应该在其他地方?2)我可以使用index.js文件来简化它吗?如果是这样,如何做链接index.js?它只是

干杯.

$(document).ready(function() {
  listenForInputChanges();
})

function listenForInputChanges() {
  $('#contactType >input').change(function() {
    console.log('val is ' + $(this).val())
    switch ($(this).val()) {
      case 'individual':
        $('#nameDiv').show();
        $('#companyDiv').show();
        $('#titleDiv').show();
        $('#phoneDiv').show();
        $('#emailDiv').show();
        $('#addressDiv').show();
        break;

      case 'team':
        $('#nameDiv').show();
        $('#companyDiv').show();
        $('#titleDiv').hide();
        $('#phoneDiv').show();
        $('#emailDiv').show();
        $('#addressDiv').show();
        break;

      case 'company':
        $('#nameDiv').hide();
        $('#companyDiv').show();
        $('#titleDiv').hide();
        $('#phoneDiv').show();
        $('#emailDiv').show();
        $('#addressDiv').show();
        break;
    }
  })
}
Run Code Online (Sandbox Code Playgroud)
<!DOCTYPE html>
<html>

<head>
  <title>Create new contact</title>
  <link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/css/bootstrap.min.css" integrity="sha384-BVYiiSIFeK1dGmJRAkycuHAHRg32OmUcww7on3RYdg4Va+PmSTsz/K68vbdEjh4u" crossorigin="anonymous">
  <script src="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/js/bootstrap.min.js">
  </script>


</head>

<body>
  <div class="container">
    <div class="row">
      <form method="post" class="form-horizontal col-md-6 col-md-offset-3">
        <h2>Motoko Insurance Contacts</h2>


        <script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js">
        </script>
        <link href="https://maxcdn.bootstrapcdn.com/bootstrap/4.0.0/css/bootstrap.min.css" rel="stylesheet" />

        <div class="form-group">
          <label for="input" class="col-sm-6 control-label">What type of contact are you adding?</label>
          <div id="contactType" class="col-sm-10">
            <input type="radio" name="Contact_type" value="individual"> Individual
            <input type="radio" name="Contact_type" value="team"> Team
            <input type="radio" name="Contact_type" value="company"> Company</div>
        </div>


        <div id="nameDiv" class="form-group">
          <label for="input1" class="col-sm-2 control-label">Name</label>
          <div class="col-sm-10">
            <input type="text" name="name" class="form-control" id="input1" placeholder="Name" />
          </div>
        </div>

        <div id="companyDiv" class="form-group">
          <label for="input1" class="col-sm-2 control-label">Company</label>
          <div class="col-sm-10">
            <input type="text" name="comp" class="form-control" id="input1" placeholder="Company" />
          </div>
        </div>

        <div id="titleDiv" class="form-group">
          <label for="input1" class="col-sm-2 control-label">Title</label>
          <div class="col-sm-10">
            <input type="text" name="title" class="form-control" id="input1" placeholder="Title" />
          </div>
        </div>

        <div id="phoneDiv" class="form-group">
          <label for="input1" class="col-sm-2 control-label">Phone</label>
          <div class="col-sm-10">
            <input type="int" name="urstel" class="form-control" id="input1" placeholder="Phone" />
          </div>
        </div>

        <div id="emailDiv" class="form-group">
          <label for="input1" class="col-sm-2 control-label">E-Mail</label>
          <div class="col-sm-10">
            <input type="email" name="email" class="form-control" id="input1" placeholder="E-mail" />
          </div>
        </div>

        <div id="addressDiv" class="form-group">
          <label for="input1" class="col-sm-2 control-label">Address</label>
          <div class="col-sm-10">
            <input type="text" name="location" class="form-control" id="input1" placeholder="Address" />
          </div>
        </div>


        <input type="submit" class="btn btn-primary col-md-2 col-md-offset-10" value="submit" />
      </form>

    </div>
  </div>
</body>

</html>
Run Code Online (Sandbox Code Playgroud)

Ger*_*NCO 5

你错过了jQuery lib.请务必在<head>页面的部分添加它:

<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
Run Code Online (Sandbox Code Playgroud)

$(document).ready(function() {
  listenForInputChanges();
})

function listenForInputChanges() {
  $('#contactType >input').change(function() {
    console.log('val is ' + $(this).val())
    switch ($(this).val()) {
      case 'individual':
        $('#nameDiv').show();
        $('#companyDiv').show();
        $('#titleDiv').show();
        $('#phoneDiv').show();
        $('#emailDiv').show();
        $('#addressDiv').show();
        break;

      case 'team':
        $('#nameDiv').show();
        $('#companyDiv').show();
        $('#titleDiv').hide();
        $('#phoneDiv').show();
        $('#emailDiv').show();
        $('#addressDiv').show();
        break;

      case 'company':
        $('#nameDiv').hide();
        $('#companyDiv').show();
        $('#titleDiv').hide();
        $('#phoneDiv').show();
        $('#emailDiv').show();
        $('#addressDiv').show();
        break;
    }
  })
}
Run Code Online (Sandbox Code Playgroud)
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<!DOCTYPE html>
<html>

<head>
  <title>Create new contact</title>
  <link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/css/bootstrap.min.css" integrity="sha384-BVYiiSIFeK1dGmJRAkycuHAHRg32OmUcww7on3RYdg4Va+PmSTsz/K68vbdEjh4u" crossorigin="anonymous">
  <script src="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/js/bootstrap.min.js">
  </script>


</head>

<body>
  <div class="container">
    <div class="row">
      <form method="post" class="form-horizontal col-md-6 col-md-offset-3">
        <h2>Motoko Insurance Contacts</h2>


        <script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js">
        </script>
        <link href="https://maxcdn.bootstrapcdn.com/bootstrap/4.0.0/css/bootstrap.min.css" rel="stylesheet" />

        <div class="form-group">
          <label for="input" class="col-sm-6 control-label">What type of contact are you adding?</label>
          <div id="contactType" class="col-sm-10">
            <input type="radio" name="Contact_type" value="individual"> Individual
            <input type="radio" name="Contact_type" value="team"> Team
            <input type="radio" name="Contact_type" value="company"> Company</div>
        </div>


        <div id="nameDiv" class="form-group">
          <label for="input1" class="col-sm-2 control-label">Name</label>
          <div class="col-sm-10">
            <input type="text" name="name" class="form-control" id="input1" placeholder="Name" />
          </div>
        </div>

        <div id="companyDiv" class="form-group">
          <label for="input1" class="col-sm-2 control-label">Company</label>
          <div class="col-sm-10">
            <input type="text" name="comp" class="form-control" id="input1" placeholder="Company" />
          </div>
        </div>

        <div id="titleDiv" class="form-group">
          <label for="input1" class="col-sm-2 control-label">Title</label>
          <div class="col-sm-10">
            <input type="text" name="title" class="form-control" id="input1" placeholder="Title" />
          </div>
        </div>

        <div id="phoneDiv" class="form-group">
          <label for="input1" class="col-sm-2 control-label">Phone</label>
          <div class="col-sm-10">
            <input type="int" name="urstel" class="form-control" id="input1" placeholder="Phone" />
          </div>
        </div>

        <div id="emailDiv" class="form-group">
          <label for="input1" class="col-sm-2 control-label">E-Mail</label>
          <div class="col-sm-10">
            <input type="email" name="email" class="form-control" id="input1" placeholder="E-mail" />
          </div>
        </div>

        <div id="addressDiv" class="form-group">
          <label for="input1" class="col-sm-2 control-label">Address</label>
          <div class="col-sm-10">
            <input type="text" name="location" class="form-control" id="input1" placeholder="Address" />
          </div>
        </div>


        <input type="submit" class="btn btn-primary col-md-2 col-md-offset-10" value="submit" />
      </form>

    </div>
  </div>
</body>

</html>
Run Code Online (Sandbox Code Playgroud)