gpt4 book ai didi

jquery - 在显示和折叠之间更改 Bootstrap 4 元素的类成员资格

转载 作者:行者123 更新时间:2023-12-01 08:41:59 25 4
gpt4 key购买 nike

我有一个导航栏,其中混合有split dropdown buttons以及上面的常规按钮。在非折叠模式下显示时看起来不错,但当导航栏折叠时,只有按钮会扩展到视口(viewport)的全宽。

根据我在 Bootstrap 4 中查看拆分下拉按钮(它是一个 btn-group)的属性检查器所看到的情况,看起来常规按钮是 的成员w-100 当它折叠时,但 btn-group 成员不是。仅当 navbar 折叠时,如何将拆分下拉按钮配置为 w-100 类的成员?

// Initialize tooltip component
$(function () {
$('[data-toggle="tooltip"]').tooltip()
})

// Initialize popover component
$(function () {
$('[data-toggle="popover"]').popover()
})
.navbar, .navbar.btn-secondary {
/* For browsers that do not support gradients */
background-color: #b32017;
/* For Safari 5.1 to 6.0 */
background: -webkit-linear-gradient(#b32017, #801710);
/* For Opera 11.1 to 12.0 */
background: -o-linear-gradient(#b32017, #801710);
/* For Firefox 3.6 to 15 */
background: -moz-linear-gradient(#b32017, #801710);
/* Standard syntax */
background: linear-gradient(#b32017, #801710);
}

.navbar .btn-secondary {
/*background-color: #b32017;*/
/* For browsers that do not support gradients */
background-color: #b32017;
/* For Safari 5.1 to 6.0 */
background: -webkit-linear-gradient(#b32017, #801710);
/* For Opera 11.1 to 12.0 */
background: -o-linear-gradient(#b32017, #801710);
/* For Firefox 3.6 to 15 */
background: -moz-linear-gradient(#b32017, #801710);
/* Standard syntax */
background: linear-gradient(#b32017, #801710);
}

.navbar img {
max-height: 40px;
}

.navbar .btn {
/* Removes Bootstrap's border */
border: 0px;
}

.navbar .navbar-brand {
color: #ffffff;
}

.navbar .navbar-brand:hover, .navbar .navbar-brand:focus {
color: #c1c1c1;
}

.navbar .navbar-text {
color: #ffffff;
}

.navbar .navbar-nav .nav-link {
color: #ffffff;
border-radius: .25rem;
margin: 0 0.25em;
}

.navbar .navbar-nav .nav-link:not(.disabled):hover, .navbar .navbar-nav .nav-link:not(.disabled):focus {
color: #c1c1c1;
}

.navbar .navbar-nav .nav-item.active .nav-link, .navbar .navbar-nav .nav-item.active .nav-link:hover, .navbar .navbar-nav .nav-item.active .nav-link:focus, .navbar .navbar-nav .nav-item.show .nav-link, .navbar .navbar-nav .nav-item.show .nav-link:hover, .navbar .navbar-nav .nav-item.show .nav-link:focus {
color: #c1c1c1;
background-color: #801710;
}

.navbar .navbar-toggle {
border-color: #801710;
}

.navbar .navbar-toggle:hover, .navbar .navbar-toggle:focus {
background-color: #801710;
}

.navbar .navbar-toggle .navbar-toggler-icon {
color: #ffffff;
}

.navbar .navbar-collapse, .navbar .navbar-form {
border-color: #ffffff;
}

.navbar .navbar-link {
color: #ffffff;
}

.navbar .navbar-link:hover {
color: #c1c1c1;
}

@media (max-width: 767px) {
.navbar .navbar-nav .open .dropdown-menu .dropdown-item .dropdown-menu.show {
/* no gradient support */
/* #cccccc */
color: #ffffff;
}
.navbar .navbar-nav .open .dropdown-menu .dropdown-item:hover, .navbar .navbar-nav .open .dropdown-menu .dropdown-item:focus {
color: #c1c1c1;
}
.navbar .navbar-nav .open .dropdown-menu .dropdown-item.active {
color: #c1c1c1;
background-color: #801710;
}
}
<script src="https://code.jquery.com/jquery-3.2.1.slim.min.js"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/popper.js/1.11.0/umd/popper.min.js"></script>
<script src="https://maxcdn.bootstrapcdn.com/bootstrap/4.0.0-beta/js/bootstrap.min.js"></script>
<link href="https://maxcdn.bootstrapcdn.com/font-awesome/4.7.0/css/font-awesome.min.css" rel="stylesheet"/>
<link href="https://maxcdn.bootstrapcdn.com/bootstrap/4.0.0-beta/css/bootstrap.min.css" rel="stylesheet"/>
<!DOCTYPE html>
<html>

<head>
<meta charset="utf-8">
<meta name="viewport" content="width=device-width, initial-scale=1, shrink-to-fit=no">
<title>Experimental Test Page</title>
</head>

<body>
<!-- Navigation -->
<nav class="navbar fixed-top navbar-expand-sm bg-faded navbar-light">
<button class="navbar-toggler" type="button" data-toggle="collapse" data-target="#nav-content" aria-controls="nav-content" aria-expanded="false" aria-label="Toggle navigation">
<span class="navbar-toggler-icon"></span>
</button>
<!-- Brand -->
<a class="navbar-brand" href="#">
</a>
<div class="collapse navbar-collapse" id="nav-content">
<ul class="navbar-nav w-100 nav-justified">
<!-- Home -->
<li class="nav-item">
<div class="btn-group">
<a href="#" class="btn btn-secondary" role="button"><i class="fa fa-fw fa-home"><!-- --></i> Home</a>
<button type="button" class="btn btn-secondary dropdown-toggle dropdown-toggle-split" data-toggle="dropdown">
</button>
<div class="dropdown-menu">
<a class="dropdown-item" href="#"><i class="fa fa-fw fa-map-marker"><!-- --></i>Hours &amp; Location</a>
</div>
</div>
</li>
<li class="nav-item">
<div class="btn-group" role="button">
<a href="#" class="btn btn-secondary" role="button">Section</a>
<button type="button" class="btn btn-secondary dropdown-toggle dropdown-toggle-split" data-toggle="dropdown">
</button>
<div class="dropdown-menu">
<a class="dropdown-item" href="#">Item 1</a>
<a class="dropdown-item" href="#">Item 2</a>
<a class="dropdown-item" href="#">Item 3</a>
<a class="dropdown-item" href="#">Item 4</a>
</div>
</div>
</li>
<li class="nav-item">
<a class="nav-link btn btn-secondary" href="#" role="button">Another Section</a>
</li>
<li class="nav-item">
<a class="nav-link btn btn-secondary" href="#" role="button">Section</a>
</li>
<li class="nav-item">
<a class="nav-link btn btn-secondary" href="#" role="button">Section</a>
</li>
<li class="nav-item">
<div class="btn-group" role="button">
<a href="#" class="btn btn-secondary" role="button">Products</a>
<button type="button" class="btn btn-secondary dropdown-toggle dropdown-toggle-split" data-toggle="dropdown">
</button>
<div class="dropdown-menu">
<a class="dropdown-item" href="#">Item 1</a>
<a class="dropdown-item" href="#">Item 2</a>
</div>
</div>
</li>
</ul>
</div>
</nav>
</body>

</html>

`

最佳答案

如果我理解正确的话,您希望按钮填充 100% 宽度。

为了实现它,您可以为 .btn-groupa.btn 设置 width: 100%,如下所示:

.btn-group,
.btn-group>.btn:first-child:not(:last-child):not(.dropdown-toggle) { width: 100%; }

打开下拉菜单时还有一个问题。要解决此问题,您应该将 .navbar-nav .dropdown-menupositionstatic 覆盖为 absolute :

.navbar-nav .dropdown-menu { position: absolute !important; }

要确保仅当 navbar 折叠时才应用此样式,您可以使用 Responsive breakpoints

// Initialize tooltip component
$(function () {
$('[data-toggle="tooltip"]').tooltip()
})

// Initialize popover component
$(function () {
$('[data-toggle="popover"]').popover()
})
.btn-group,
.btn-group>.btn:first-child:not(:last-child):not(.dropdown-toggle) { width: 100%; }
.navbar-nav .dropdown-menu { position: absolute !important; }

.navbar, .navbar.btn-secondary {
/* For browsers that do not support gradients */
background-color: #b32017;
/* For Safari 5.1 to 6.0 */
background: -webkit-linear-gradient(#b32017, #801710);
/* For Opera 11.1 to 12.0 */
background: -o-linear-gradient(#b32017, #801710);
/* For Firefox 3.6 to 15 */
background: -moz-linear-gradient(#b32017, #801710);
/* Standard syntax */
background: linear-gradient(#b32017, #801710);
}

.navbar .btn-secondary {
/*background-color: #b32017;*/
/* For browsers that do not support gradients */
background-color: #b32017;
/* For Safari 5.1 to 6.0 */
background: -webkit-linear-gradient(#b32017, #801710);
/* For Opera 11.1 to 12.0 */
background: -o-linear-gradient(#b32017, #801710);
/* For Firefox 3.6 to 15 */
background: -moz-linear-gradient(#b32017, #801710);
/* Standard syntax */
background: linear-gradient(#b32017, #801710);
}

.navbar img {
max-height: 40px;
}

.navbar .btn {
/* Removes Bootstrap's border */
border: 0px;
}

.navbar .navbar-brand {
color: #ffffff;
}

.navbar .navbar-brand:hover, .navbar .navbar-brand:focus {
color: #c1c1c1;
}

.navbar .navbar-text {
color: #ffffff;
}

.navbar .navbar-nav .nav-link {
color: #ffffff;
border-radius: .25rem;
margin: 0 0.25em;
}

.navbar .navbar-nav .nav-link:not(.disabled):hover, .navbar .navbar-nav .nav-link:not(.disabled):focus {
color: #c1c1c1;
}

.navbar .navbar-nav .nav-item.active .nav-link, .navbar .navbar-nav .nav-item.active .nav-link:hover, .navbar .navbar-nav .nav-item.active .nav-link:focus, .navbar .navbar-nav .nav-item.show .nav-link, .navbar .navbar-nav .nav-item.show .nav-link:hover, .navbar .navbar-nav .nav-item.show .nav-link:focus {
color: #c1c1c1;
background-color: #801710;
}

.navbar .navbar-toggle {
border-color: #801710;
}

.navbar .navbar-toggle:hover, .navbar .navbar-toggle:focus {
background-color: #801710;
}

.navbar .navbar-toggle .navbar-toggler-icon {
color: #ffffff;
}

.navbar .navbar-collapse, .navbar .navbar-form {
border-color: #ffffff;
}

.navbar .navbar-link {
color: #ffffff;
}

.navbar .navbar-link:hover {
color: #c1c1c1;
}

@media (max-width: 767px) {
.navbar .navbar-nav .open .dropdown-menu .dropdown-item .dropdown-menu.show {
/* no gradient support */
/* #cccccc */
color: #ffffff;
}
.navbar .navbar-nav .open .dropdown-menu .dropdown-item:hover, .navbar .navbar-nav .open .dropdown-menu .dropdown-item:focus {
color: #c1c1c1;
}
.navbar .navbar-nav .open .dropdown-menu .dropdown-item.active {
color: #c1c1c1;
background-color: #801710;
}
}
<script src="https://code.jquery.com/jquery-3.2.1.slim.min.js"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/popper.js/1.11.0/umd/popper.min.js"></script>
<script src="https://maxcdn.bootstrapcdn.com/bootstrap/4.0.0-beta/js/bootstrap.min.js"></script>
<link href="https://maxcdn.bootstrapcdn.com/font-awesome/4.7.0/css/font-awesome.min.css" rel="stylesheet"/>
<link href="https://maxcdn.bootstrapcdn.com/bootstrap/4.0.0-beta/css/bootstrap.min.css" rel="stylesheet"/>
<!DOCTYPE html>
<html>

<head>
<meta charset="utf-8">
<meta name="viewport" content="width=device-width, initial-scale=1, shrink-to-fit=no">
<title>Experimental Test Page</title>
</head>

<body>
<!-- Navigation -->
<nav class="navbar fixed-top navbar-expand-sm bg-faded navbar-light">
<button class="navbar-toggler" type="button" data-toggle="collapse" data-target="#nav-content" aria-controls="nav-content" aria-expanded="false" aria-label="Toggle navigation">
<span class="navbar-toggler-icon"></span>
</button>
<!-- Brand -->
<a class="navbar-brand" href="#">
</a>
<div class="collapse navbar-collapse" id="nav-content">
<ul class="navbar-nav w-100 nav-justified">
<!-- Home -->
<li class="nav-item">
<div class="btn-group">
<a href="#" class="btn btn-secondary" role="button"><i class="fa fa-fw fa-home"><!-- --></i> Home</a>
<button type="button" class="btn btn-secondary dropdown-toggle dropdown-toggle-split" data-toggle="dropdown">
</button>
<div class="dropdown-menu">
<a class="dropdown-item" href="#"><i class="fa fa-fw fa-map-marker"><!-- --></i>Hours &amp; Location</a>
</div>
</div>
</li>
<li class="nav-item">
<div class="btn-group" role="button">
<a href="#" class="btn btn-secondary" role="button">Section</a>
<button type="button" class="btn btn-secondary dropdown-toggle dropdown-toggle-split" data-toggle="dropdown">
</button>
<div class="dropdown-menu">
<a class="dropdown-item" href="#">Item 1</a>
<a class="dropdown-item" href="#">Item 2</a>
<a class="dropdown-item" href="#">Item 3</a>
<a class="dropdown-item" href="#">Item 4</a>
</div>
</div>
</li>
<li class="nav-item">
<a class="nav-link btn btn-secondary" href="#" role="button">Another Section</a>
</li>
<li class="nav-item">
<a class="nav-link btn btn-secondary" href="#" role="button">Section</a>
</li>
<li class="nav-item">
<a class="nav-link btn btn-secondary" href="#" role="button">Section</a>
</li>
<li class="nav-item">
<div class="btn-group" role="button">
<a href="#" class="btn btn-secondary" role="button">Products</a>
<button type="button" class="btn btn-secondary dropdown-toggle dropdown-toggle-split" data-toggle="dropdown">
</button>
<div class="dropdown-menu">
<a class="dropdown-item" href="#">Item 1</a>
<a class="dropdown-item" href="#">Item 2</a>
</div>
</div>
</li>
</ul>
</div>
</nav>
</body>

</html>

关于jquery - 在显示和折叠之间更改 Bootstrap 4 元素的类成员资格,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/45882658/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com