bootstrap-切换开关显示为复选框
bootstrap-toggle switch is showing up as a checkbox
我在 React 中有一个 ToggleSwitch 组件,它是我使用 bootstrap-toggle
制作的。但它显示为复选框而不是切换开关。关于如何使其工作的任何帮助?
ToggleSwitch.js
import React, { Component } from "react";
import "bootstrap/dist/css/bootstrap.css";
import "bootstrap-toggle/css/bootstrap-toggle.css";
class ToggleSwitch extends Component {
render() {
return (
<div className="toggle-switch">
<input
type="checkbox"
data-toggle="toggle"
data-on="Ready"
data-off="Not Ready"
data-onstyle="success"
data-offstyle="danger"
/>
</div>
);
}
}
export default ToggleSwitch;
调用 JavaScript 个文件的顺序可能有问题。
对于CSS调用必要的文件:
- Bootstrap 4
- Bootstrap4-切换
对于 JavaScript,按以下顺序调用文件:
- jQuery 苗条
- Bootstrap 4
- Bootstrap4-切换
工作片段:
const element = (
<div className="toggle-switch">
<input
type="checkbox"
data-toggle="toggle"
data-on="Ready"
data-off="Not Ready"
data-onstyle="success"
data-offstyle="danger"
/>
</div>
);
ReactDOM.render(
element,
document.getElementById('app')
);
<link href="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/4.1.3/css/bootstrap.min.css" rel="stylesheet"/>
<link href="https://cdn.jsdelivr.net/gh/gitbrent/bootstrap4-toggle@3.6.1/css/bootstrap4-toggle.min.css" rel="stylesheet"/>
<div id="app"></div>
<script src="https://cdnjs.cloudflare.com/ajax/libs/react/16.6.3/umd/react.production.min.js"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/react-dom/16.6.3/umd/react-dom.production.min.js"></script>
<script src="https://code.jquery.com/jquery-3.4.1.slim.min.js"></script>
<script src="https://stackpath.bootstrapcdn.com/bootstrap/4.4.1/js/bootstrap.min.js"></script>
<script src="https://cdn.jsdelivr.net/gh/gitbrent/bootstrap4-toggle@3.6.1/js/bootstrap4-toggle.min.js"></script>
我对 Bootstrap toggle buttons 也有类似的问题——显示了切换按钮,但也显示了复选框。 我尝试了接受的答案(确认了我的 Bootstrap CSS/JS 文件引用),但仍然没有用。
我的问题的根源最终是我有一个 自定义 CSS sheet 具有以下规则:
.form-group input {
position: relative;
z-index: 2;
}
...我的 切换按钮嵌套如下:
<div class="form-control">
...
<input type="checkbox" class="btn-check" id="btn-check" autocomplete="off">
<label class="btn btn-primary" for="btn-check">Single toggle</label>
...
</div>
解决方案:
确保你没有任何 Bootstrap-overriding CSS 改变期望的规则! 一旦我摆脱了那个压倒一切的 .form-control input
CSS规则,它正常工作!
快速测试(看看是否有一个压倒一切的 CSS 规则是你的问题): 将你的切换按钮放在任何其他 tags/classes 如果可以,看看它是否正常工作。
- 在我的例子中,一旦我把它从包含 class “form-control” 的 div 中移出,它就可以正常工作,所以它指出了我正确的方向——我知道这与我的习惯 CSS 规则有关!
如果快速测试失败: 您仍然可以覆盖 CSS 规则:
input
input[type="checkbox"]
- ...或输入标签中的 classes/id/names/other 属性之一(例如 class 或 id
btn-check
Bootstrap 切换按钮)
在其中一种情况下,即使将它放在其他 tags/classes 之外也不起作用,因此您仍应检查任何 custom/additional CSS rules/sheets 用于覆盖!
我在 React 中有一个 ToggleSwitch 组件,它是我使用 bootstrap-toggle
制作的。但它显示为复选框而不是切换开关。关于如何使其工作的任何帮助?
ToggleSwitch.js
import React, { Component } from "react";
import "bootstrap/dist/css/bootstrap.css";
import "bootstrap-toggle/css/bootstrap-toggle.css";
class ToggleSwitch extends Component {
render() {
return (
<div className="toggle-switch">
<input
type="checkbox"
data-toggle="toggle"
data-on="Ready"
data-off="Not Ready"
data-onstyle="success"
data-offstyle="danger"
/>
</div>
);
}
}
export default ToggleSwitch;
调用 JavaScript 个文件的顺序可能有问题。
对于CSS调用必要的文件:
- Bootstrap 4
- Bootstrap4-切换
对于 JavaScript,按以下顺序调用文件:
- jQuery 苗条
- Bootstrap 4
- Bootstrap4-切换
工作片段:
const element = (
<div className="toggle-switch">
<input
type="checkbox"
data-toggle="toggle"
data-on="Ready"
data-off="Not Ready"
data-onstyle="success"
data-offstyle="danger"
/>
</div>
);
ReactDOM.render(
element,
document.getElementById('app')
);
<link href="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/4.1.3/css/bootstrap.min.css" rel="stylesheet"/>
<link href="https://cdn.jsdelivr.net/gh/gitbrent/bootstrap4-toggle@3.6.1/css/bootstrap4-toggle.min.css" rel="stylesheet"/>
<div id="app"></div>
<script src="https://cdnjs.cloudflare.com/ajax/libs/react/16.6.3/umd/react.production.min.js"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/react-dom/16.6.3/umd/react-dom.production.min.js"></script>
<script src="https://code.jquery.com/jquery-3.4.1.slim.min.js"></script>
<script src="https://stackpath.bootstrapcdn.com/bootstrap/4.4.1/js/bootstrap.min.js"></script>
<script src="https://cdn.jsdelivr.net/gh/gitbrent/bootstrap4-toggle@3.6.1/js/bootstrap4-toggle.min.js"></script>
我对 Bootstrap toggle buttons 也有类似的问题——显示了切换按钮,但也显示了复选框。 我尝试了接受的答案(确认了我的 Bootstrap CSS/JS 文件引用),但仍然没有用。
我的问题的根源最终是我有一个 自定义 CSS sheet 具有以下规则:
.form-group input {
position: relative;
z-index: 2;
}
...我的 切换按钮嵌套如下:
<div class="form-control">
...
<input type="checkbox" class="btn-check" id="btn-check" autocomplete="off">
<label class="btn btn-primary" for="btn-check">Single toggle</label>
...
</div>
解决方案:
确保你没有任何 Bootstrap-overriding CSS 改变期望的规则! 一旦我摆脱了那个压倒一切的 .form-control input
CSS规则,它正常工作!
快速测试(看看是否有一个压倒一切的 CSS 规则是你的问题): 将你的切换按钮放在任何其他 tags/classes 如果可以,看看它是否正常工作。
- 在我的例子中,一旦我把它从包含 class “form-control” 的 div 中移出,它就可以正常工作,所以它指出了我正确的方向——我知道这与我的习惯 CSS 规则有关!
如果快速测试失败: 您仍然可以覆盖 CSS 规则:
input
input[type="checkbox"]
- ...或输入标签中的 classes/id/names/other 属性之一(例如 class 或 id
btn-check
Bootstrap 切换按钮)
在其中一种情况下,即使将它放在其他 tags/classes 之外也不起作用,因此您仍应检查任何 custom/additional CSS rules/sheets 用于覆盖!