iCheck.js单选按钮将在表格(32)表格时自动检查



我正在使用iCheck http://icheck.fronteed.com/使用精美的无线电按钮和复选框。我遇到了一个问题。当我浏览我的表格并经过广播按钮时,它会自动检查一个广播按钮。

http://jsfiddle.net/75qmj037/7/

这是一个示例,只需通过表单浏览表格,然后查看它如何自动检查单选按钮。有谁知道我如何更改iCheck.js,以免发生这种情况?我仍在尝试通过无线电按钮进行标签,但没有自动检查第一个按钮。我希望它们与悬停外观具有相同的效果。

我看过其他论坛说这是一个正在研究的问题,但这是几年前,找不到解决方案。

对此的任何帮助将不胜感激!

<fieldset class="radio-strip">
    <label class="checked">
      <input name="amt" value="10" type="radio">
      <span class="label-text">$<strong>10</strong></span>
    </label>
    <label>
      <input name="amt" value="25" type="radio">
      <span class="label-text">$<strong>25</strong></span>
    </label>
    <label>
      <input name="amt" value="50" type="radio">
      <span class="label-text">$<strong>50</strong></span>
    </label>
    <label>
      <input name="amt" value="100" type="radio">
      <span class="label-text">$<strong>100</strong></span>
    </label>
  </fieldset>
</body>
jQuery('input').iCheck({
  checkboxClass: 'icheckbox_square-blue',
  radioClass: 'iradio_square-blue',
  increaseArea: '20%' // optional
});

但是,有一个问题。您如何区分您是哪个广播按钮?

您可以在无需jQuery或任何插件的情况下样式的无线电输入元素。

我删除了表结构,因为它是不必要的HTML并用Div元素代替的。

请参阅此示例(更新代码)

body {
  background-color: white;
  margin: 0;
  padding: 0;
}
input[type='radio'] {
  display: none;
}
.radio {
  border: 1px solid #b3b4b4;
  border-radius: 50%;
  box-sizing: border-box;
  cursor: pointer;
  display: block;
  float: left;
  height: 16px;
  margin: 10px 10px 0 0;
  padding: 10px;
  position: relative;
  width: 16px;
}
.row:hover .radio {
  border: 2px solid #218996;
}
input[type='radio']:checked + .radio {
  background-color: #218996;
  border: 2px solid #218996;
}
input[type='radio']:checked + .radio::before {
  content: "✓ ";
  position: absolute;
  color: white;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  font-size:
}
.row {
  border-bottom: 1px solid #dcdcdc;
  padding: 0 5px;
}
.row label {
  display: inline-block;
  font-family: "Helvetica Neue", Helvetica, Arial, sans-serif;
  font-size: 14px;
  font-weight: bold;
}
.row > label:last-child {
  padding: 12px 0;
  width: calc(100% - 50px);
  cursor: pointer;
}
<form name="titleTypes" id="titleTypes" method="post" action="process.cfm">
  <div>
    <!---Label is here for placement of error message--->
    <label for="rgroup" class="error" style="display:none;">Please choose one.</label>
  </div>
  <div class='row'>
    <input id="one" type="radio" name="rgroup" value="MV/titleTypeMV.cfm" />
    <label for="one" class='radio' tabindex='1'></label>
    <label for="one">MOTOR VEHICLE / TRAVEL TRAILER TITLE</label>
  </div>
  <div class='row'>
    <input id="two" type="radio" name="rgroup" value="MH/mobileHome.cfm" />
    <label for="two" class='radio' tabindex='1'></label>
    <label for="two">MOBILE HOME</label>
  </div>
  <div class='row'>
    <input id="three" type="radio" name="rgroup" value="BOAT/boat.cfm" />
    <label for="three" class='radio' tabindex='1'></label>
    <label for="three">VESSEL</label>
  </div>
  <div class='row'>
    <input id="four" type="radio" name="rgroup" value="DUPL/duplicate.cfm" />
    <label for="four" class='radio' tabindex='1'></label>
    <label for="four">DUPLICATE</label>
  </div>
  <div>
    <button class="btn-u" type="submit" name="submit" id="submitBtn" class="submitBtn"><i></i>Next</button>
  </div>

这将解决问题,但您必须在每个元素中添加TabIndex(所有元素可能是相同的值)。

来自mdn:

TabIndex全局属性是一个整数,指示该元素是否可以采用输入焦点(可集中),是否应该参与顺序键盘导航,如果是的,则在什么位置处。它可以采用几个值:

负值意味着该元素应该是可集中的,但不应通过顺序键盘导航到达;

因此,您可以将Tabindex设置为-1的收音机按钮:

摘要:

jQuery('input').iCheck({
  checkboxClass: 'icheckbox_square-blue',
  radioClass: 'iradio_square-blue',
  increaseArea: '20%' // optional
});
jQuery('input').attr("tabindex", "-1");
.icheckbox_square-blue,
.iradio_square-blue {
  display: inline-block;
  *display: inline;
  vertical-align: middle;
  margin: 0;
  padding: 0;
  width: 22px;
  height: 22px;
  background: url('') no-repeat;
  border: none;
  cursor: pointer;
}
.icheckbox_square-blue {
  background-position: 0 0;
}
.icheckbox_square-blue.hover {
  background-position: -24px 0;
}
.icheckbox_square-blue.checked {
  background-position: -48px 0;
}
.icheckbox_square-blue.disabled {
  background-position: -72px 0;
  cursor: default;
}
.icheckbox_square-blue.checked.disabled {
  background-position: -96px 0;
}
.iradio_square-blue {
  background-position: -120px 0;
}
.iradio_square-blue.hover {
  background-position: -144px 0;
}
.iradio_square-blue.checked {
  background-position: -168px 0;
}
.iradio_square-blue.disabled {
  background-position: -192px 0;
  cursor: default;
}
.iradio_square-blue.checked.disabled {
  background-position: -216px 0;
}

/* HiDPI support */
@media (-o-min-device-pixel-ratio: 5/4),
  (-webkit-min-device-pixel-ratio: 1.25),
  (min-resolution: 120dpi),
  (min-resolution: 1.25dppx) {
    .icheckbox_square-blue,
    .iradio_square-blue {
      background-image: url('');
      -webkit-background-size: 240px 24px;
      background-size: 240px 24px;
    }
  }
<link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/css/bootstrap.min.css">
<script src="https://code.jquery.com/jquery-2.1.1.min.js"></script>
<script src="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/js/bootstrap.min.js"></script>
<script src="https://cdn.rawgit.com/fronteed/icheck/1.x/icheck.min.js"></script>

<fieldset class="radio-strip">
    <label class="checked">
        <input name="amt" value="10" type="radio">
        <span class="label-text">$<strong>10</strong></span>
    </label>
    <label>
        <input name="amt" value="25" type="radio">
        <span class="label-text">$<strong>25</strong></span>
    </label>
    <label>
        <input name="amt" value="50" type="radio">
        <span class="label-text">$<strong>50</strong></span>
    </label>
    <label>
        <input name="amt" value="100" type="radio">
        <span class="label-text">$<strong>100</strong></span>
    </label>
</fieldset>

最新更新