- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
当浏览器的窗口大小调整到右侧 900px 以下时,我想对齐通过 flex-wrap:wrap 插入第二行的元素(元素的数量可能会有所不同)。
我使用 flex-wrap:wrap 是因为最初的问题是,当浏览器窗口太小时整个菜单栏太宽了。
Wrap 解决了这个问题,但是折叠的子菜单“粘”在菜单栏的主要元素后面(例如 Link 7 后面的 Link 3.1)
如果有人能提供比 flex-wrap:wrap 更好的解决方案,我将不胜感激。
我尝试使用不同版本的 justify-content 来解决该问题。但它要么根本不起作用,要么整个菜单栏都受到影响。
所以主要问题是:如何仅将那些位于“第二个 flex 行”中的元素对齐到右侧?
我还创建了一支笔:[但是我不能发两个以上的链接,所以我打算把笔发到评论里]
jQuery(document).ready(function($) {
// add JS-classes into the HTML-Tag
$('html').addClass('js');
// add classes for sub menus and sub menus toggle button
$(".site-nav li > ul").parent('li').addClass('has-sub-menu');
$(".site-nav li > ul").addClass('sub-menu');
// create button for expand- und collapse the menu and render it into the header
var create_toggle_nav_button = ['<div class="toggle-site-nav">Menu</div>'].join("");
$("header").append(create_toggle_nav_button);
// create button for expand- und collapse the sub menu for mobile view and add them to all sub menus
var create_sub_toggle_button = ['<span class="toggle-sub-menu"></span>'].join("");
$(".has-sub-menu > a").after(create_sub_toggle_button);
// define variables
var $menu = $('.site-nav'),
$toggle_nav = $('.toggle-site-nav'),
$toggle_sub_menu = $('.toggle-sub-menu');
// collapse and expand function of the main menu
$toggle_nav.click(function(e) {
e.preventDefault();
$menu.slideToggle();
});
// collapse and expand function of the drop down menu for mobile view
$toggle_sub_menu.click(function(e) {
e.preventDefault();
var $this = $(this);
$this.toggleClass('active').next('ul').slideToggle();
});
// display hidden elements again, when browserwindow is resized by user
$(window).resize(function() {
var w = $(window).width();
if (w > 900) {
$('.site-nav').removeAttr('style');
$('.sub-menu').removeAttr('style');
}
});
// collapse navigation automatically to the left, when it run out of the viewport
$(".site-nav .has-sub-menu").on('mouseenter mouseleave', function(e) {
var nav_element = $('ul:first', this);
var element_offset = nav_element.offset();
var element_offset_left = element_offset.left;
var element_width = nav_element.width();
var viewport_width = $(window).width();
var element_in_viewport = (element_offset_left + element_width <= viewport_width);
if (!element_in_viewport) {
$(this).addClass('sub-left');
} else {
$(this).removeClass('sub-left');
}
});
});
* {
margin: 0;
padding: 0;
list-style: none;
-webkit-box-sizing: border-box;
-moz-box-sizing: border-box;
box-sizing: border-box;
font-family: "Helvetica Neue", Helvetica, Arial, sans-serif;
}
body::after {
content: '';
position: fixed;
bottom: 1em;
right: 1em;
opacity: 0.5;
font-size: 0.8em;
z-index: 9999;
}
header {
width: 100%;
background: white;
}
.container {
max-width: 1000px;
margin: 0 auto;
}
.logo {
display: block;
width: 100%;
padding: 1em;
text-decoration: none;
color: gray;
/* ? */
}
.site-nav {
z-index: 9999;
}
.site-nav>ul {
display: flex;
flex-direction: row;
justify-content: center;
align-items: stretch;
flex-wrap: wrap;
}
.site-nav li {
display: inline-block;
flex-wrap: wrap;
width: auto;
padding: 0;
position: relative;
z-index: 9999;
}
.site-nav a {
display: inline-flex;
align-content: stretch;
padding: 1em;
white-space: nowrap;
text-decoration: none;
height: 100%;
width: 100%;
color: white;
/* text color of all */
background: #5a595a;
/* background color main nav Link 1 */
border-top: 1px solid rgba(0, 0, 0, 0.5);
z-index: 9999;
}
.site-nav a:hover {
background: rgba(0, 0, 0, 0.4);
/* mouseover color Link 1 and Link 1.1 */
}
.js .site-nav {
display: none;
}
.js .sub-menu {
display: none;
position: absolute;
top: 100%;
left: 0px;
}
.js .sub-menu .sub-menu {
top: 0px;
left: 100%;
}
.js .has-sub-menu {
position: relative;
top: 100%;
left: 0px;
}
.sub-menu li:last-of-type {
padding-bottom: 0;
}
.sub-menu a {
background: #676567;
/* background color menu 2.1 only */
}
.sub-menu .sub-menu a {
background: #747274;
/* background color menu 2.1.1 only */
}
.sub-menu .sub-menu a:hover {
background: rgba(0, 0, 0, 0.4);
/* mouseover color Link 1 and Link 1.1 */
}
/* toggles */
.toggle-site-nav {
background: #5a595a;
/* background color of menu button when resized */
display: block;
position: absolute;
right: 0;
top: 0;
padding: 1em;
color: white;
/* text color of the word menu in menu button when resized */
cursor: pointer;
z-index: 9999;
}
.toggle-site-nav:hover {
background: rgba(0, 0, 0, 0.5);
/* mouseover color of menu button when resized */
}
.toggle-sub-menu {
display: none;
}
.js .toggle-sub-menu {
display: flex;
position: absolute;
align-content: center;
right: 0em;
top: 1.05em;
/* hight of the borders */
background: #817e81;
/* backgound of annoying squares when resized */
height: 15px;
width: 15px;
cursor: pointer;
z-index: 10000;
}
.js .toggle-sub-menu.active {
background: #DCDCDC;
/* color of annoying square after clicking on it when resized */
}
.toggle-sub-menu:hover,
.toggle-sub-menu.active:hover {
background-color: rgba(0, 0, 0, 0.4);
/* mouseover of annoying squares when resized */
}
@media screen and (min-width:900px) {
.logo {
width: auto;
float: left;
}
.site-nav {
width: auto;
display: block !important;
}
.site-nav a {
border: none;
}
.site-nav li {
width: auto;
padding: 0;
}
.site-nav li:hover {
background: rgba(52, 50, 52, 1);
/* mouseover background color of all menu */
}
.has-sub-menu a {
padding-right: 2em;
/* check this value */
}
.has-sub-menu:after {
/* check this for editing the stripes */
display: flex;
content: '';
position: absolute;
align-content: center;
top: 1.2em;
right: 0;
width: 0.5em;
height: 25%;
background: #817e81;
/* color of stripes in main menu when it has submenu */
}
/* sub menu */
.site-nav li:hover>.sub-menu {
display: block;
position: absolute;
width: 300px;
padding: 0 25px 25px 25px;
left: -25px;
}
.sub-menu {
display: none;
}
.sub-menu li {
width: 100%;
}
.sub-menu>a {
width: 100%;
display: block;
}
.has-sub-menu .has-sub-menu:after {
background: #817e81;
/* color of stripes of Link 2.1 menu when it has submenu */
}
.has-sub-menu .has-sub-menu:hover .sub-menu {
display: block;
position: absolute;
width: 300px;
padding: 0 25px 25px 25px;
left: 224px;
top: 0px;
}
.toggle-site-nav,
.toggle-sub-menu {
display: none !important;
}
/* navigations items, which collapse to the left */
.sub-left>.sub-menu {
left: auto;
right: 0;
}
.site-nav .sub-menu .sub-left>.sub-menu {
left: -275px;
}
}
@media (max-width :800px) {
.site-nav {
z-index: 999999999999999999;
margin-top: 25px;
}
}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<header>
<div class="container">
<a href="#" class="logo"></a>
<nav class="site-nav">
<ul>
<li><a href="#">Link 1</a></li>
<li><a href="#">Link 2</a>
<ul>
<li><a href="#">Link 2.1</a></li>
<li><a href="#">Link 2.1</a>
<ul>
<li><a href="#">Link 2.1.1</a></li>
<li><a href="#">Link 2.1.2</a></li>
<li><a href="#">Link 2.1.3</a></li>
<li><a href="#">Link 2.1.4</a></li>
</ul>
</li>
<li><a href="#">Link 2.1</a></li>
</ul>
</li>
<li><a href="#">Link 3</a>
<ul>
<li><a href="#">Link 3.1</a></li>
<li><a href="#">Link 3.2</a></li>
<li><a href="#">Link 3.3</a></li>
<li><a href="#">Link 3.4</a></li>
<li><a href="#">Link 3.5</a></li>
</ul>
</li>
<li><a href="#">Link 4</a></li>
<li><a href="#">Link 5</a></li>
<li><a href="#">Link 6</a></li>
<li><a href="#">Link 7</a>
<ul>
<li><a href="#">Link 7.1</a></li>
<li><a href="#">Link 7.2</a></li>
<li><a href="#">Link 7.3</a>
<ul>
<li><a href="#">Link 7.3.1</a></li>
<li><a href="#">Link 7.3.2</a></li>
<li><a href="#">Link 7.3.3</a></li>
<li><a href="#">Link 7.3.4</a></li>
<li><a href="#">Link 7.3.5</a></li>
</ul>
</li>
<li><a href="#">Link 7.4</a></li>
<li><a href="#">Link 7.5</a></li>
</ul>
</li>
<li><a href="#">Link 8</a></li>
</ul>
</nav>
</div>
</header>
最佳答案
将以下内容添加到 site-nav
:
@media screen and (min-width: 900px) {
.site-nav {
width: auto;
display: flex;
}
}
然后你可以将margin-auto
应用到ul
,将ajdust justify-content
应用到flex-end
(这将使 li
右对齐。
您可能需要调整 site-nav
上的 margin-top
属性以正确对齐。
jQuery(document).ready(function($) {
// add JS-classes into the HTML-Tag
$('html').addClass('js');
// add classes for sub menus and sub menus toggle button
$(".site-nav li > ul").parent('li').addClass('has-sub-menu');
$(".site-nav li > ul").addClass('sub-menu');
// create button for expand- und collapse the menu and render it into the header
var create_toggle_nav_button = ['<div class="toggle-site-nav">Menu</div>'].join("");
$("header").append(create_toggle_nav_button);
// create button for expand- und collapse the sub menu for mobile view and add them to all sub menus
var create_sub_toggle_button = ['<span class="toggle-sub-menu"></span>'].join("");
$(".has-sub-menu > a").after(create_sub_toggle_button);
// define variables
var $menu = $('.site-nav'),
$toggle_nav = $('.toggle-site-nav'),
$toggle_sub_menu = $('.toggle-sub-menu');
// collapse and expand function of the main menu
$toggle_nav.click(function(e) {
e.preventDefault();
$menu.slideToggle();
});
// collapse and expand function of the drop down menu for mobile view
$toggle_sub_menu.click(function(e) {
e.preventDefault();
var $this = $(this);
$this.toggleClass('active').next('ul').slideToggle();
});
// display hidden elements again, when browserwindow is resized by user
$(window).resize(function() {
var w = $(window).width();
if (w > 900) {
$('.site-nav').removeAttr('style');
$('.sub-menu').removeAttr('style');
}
});
// collapse navigation automatically to the left, when it run out of the viewport
$(".site-nav .has-sub-menu").on('mouseenter mouseleave', function(e) {
var nav_element = $('ul:first', this);
var element_offset = nav_element.offset();
var element_offset_left = element_offset.left;
var element_width = nav_element.width();
var viewport_width = $(window).width();
var element_in_viewport = (element_offset_left + element_width <= viewport_width);
if (!element_in_viewport) {
$(this).addClass('sub-left');
} else {
$(this).removeClass('sub-left');
}
});
});
* {
margin: 0;
padding: 0;
list-style: none;
-webkit-box-sizing: border-box;
-moz-box-sizing: border-box;
box-sizing: border-box;
font-family: "Helvetica Neue", Helvetica, Arial, sans-serif;
}
body::after {
content: '';
position: fixed;
bottom: 1em;
right: 1em;
opacity: 0.5;
font-size: 0.8em;
z-index: 9999;
}
header {
width: 100%;
background: white;
}
.container {
max-width: 1000px;
margin: 0 auto;
}
.logo {
display: block;
width: 100%;
padding: 1em;
text-decoration: none;
color: gray;
/* ? */
}
.site-nav {
z-index: 9999;
}
.site-nav>ul {
display: flex;
flex-direction: row;
justify-content: flex-end;
align-items: stretch;
flex-wrap: wrap;
margin: auto;
}
.site-nav li {
display: inline-block;
flex-wrap: wrap;
width: auto;
padding: 0;
position: relative;
z-index: 9999;
}
.site-nav a {
display: inline-flex;
align-content: stretch;
padding: 1em;
white-space: nowrap;
text-decoration: none;
height: 100%;
width: 100%;
color: white;
/* text color of all */
background: #5a595a;
/* background color main nav Link 1 */
border-top: 1px solid rgba(0, 0, 0, 0.5);
z-index: 9999;
}
.site-nav a:hover {
background: rgba(0, 0, 0, 0.4);
/* mouseover color Link 1 and Link 1.1 */
}
.js .site-nav {
display: none;
}
.js .sub-menu {
display: none;
position: absolute;
top: 100%;
left: 0px;
}
.js .sub-menu .sub-menu {
top: 0px;
left: 100%;
}
.js .has-sub-menu {
position: relative;
top: 100%;
left: 0px;
}
.sub-menu li:last-of-type {
padding-bottom: 0;
}
.sub-menu a {
background: #676567;
/* background color menu 2.1 only */
}
.sub-menu .sub-menu a {
background: #747274;
/* background color menu 2.1.1 only */
}
.sub-menu .sub-menu a:hover {
background: rgba(0, 0, 0, 0.4);
/* mouseover color Link 1 and Link 1.1 */
}
/* toggles */
.toggle-site-nav {
background: #5a595a;
/* background color of menu button when resized */
display: block;
position: absolute;
right: 0;
top: 0;
padding: 1em;
color: white;
/* text color of the word menu in menu button when resized */
cursor: pointer;
z-index: 9999;
}
.toggle-site-nav:hover {
background: rgba(0, 0, 0, 0.5);
/* mouseover color of menu button when resized */
}
.toggle-sub-menu {
display: none;
}
.js .toggle-sub-menu {
display: flex;
position: absolute;
align-content: center;
right: 0em;
top: 1.05em;
/* hight of the borders */
background: #817e81;
/* backgound of annoying squares when resized */
height: 15px;
width: 15px;
cursor: pointer;
z-index: 10000;
}
.js .toggle-sub-menu.active {
background: #DCDCDC;
/* color of annoying square after clicking on it when resized */
}
.toggle-sub-menu:hover,
.toggle-sub-menu.active:hover {
background-color: rgba(0, 0, 0, 0.4);
/* mouseover of annoying squares when resized */
}
@media screen and (min-width:900px) {
.logo {
width: auto;
float: left;
}
.site-nav {
width: auto;
display: flex !important;
}
.site-nav a {
border: none;
}
.site-nav li {
width: auto;
padding: 0;
}
.site-nav li:hover {
background: rgba(52, 50, 52, 1);
/* mouseover background color of all menu */
}
.has-sub-menu a {
padding-right: 2em;
/* check this value */
}
.has-sub-menu:after {
/* check this for editing the stripes */
display: flex;
content: '';
position: absolute;
align-content: center;
top: 1.2em;
right: 0;
width: 0.5em;
height: 25%;
background: #817e81;
/* color of stripes in main menu when it has submenu */
}
/* sub menu */
.site-nav li:hover>.sub-menu {
display: block;
position: absolute;
width: 300px;
padding: 0 25px 25px 25px;
left: -25px;
}
.sub-menu {
display: none;
}
.sub-menu li {
width: 100%;
}
.sub-menu>a {
width: 100%;
display: block;
}
.has-sub-menu .has-sub-menu:after {
background: #817e81;
/* color of stripes of Link 2.1 menu when it has submenu */
}
.has-sub-menu .has-sub-menu:hover .sub-menu {
display: block;
position: absolute;
width: 300px;
padding: 0 25px 25px 25px;
left: 224px;
top: 0px;
}
.toggle-site-nav,
.toggle-sub-menu {
display: none !important;
}
/* navigations items, which collapse to the left */
.sub-left>.sub-menu {
left: auto;
right: 0;
}
.site-nav .sub-menu .sub-left>.sub-menu {
left: -275px;
}
}
@media (max-width :800px) {
.site-nav {
z-index: 999999999999999999;
margin-top: 18px;
}
}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<header>
<div class="container">
<a href="#" class="logo"></a>
<nav class="site-nav">
<ul>
<li><a href="#">Link 1</a></li>
<li><a href="#">Link 2</a>
<ul>
<li><a href="#">Link 2.1</a></li>
<li><a href="#">Link 2.1</a>
<ul>
<li><a href="#">Link 2.1.1</a></li>
<li><a href="#">Link 2.1.2</a></li>
<li><a href="#">Link 2.1.3</a></li>
<li><a href="#">Link 2.1.4</a></li>
</ul>
</li>
<li><a href="#">Link 2.1</a></li>
</ul>
</li>
<li><a href="#">Link 3</a>
<ul>
<li><a href="#">Link 3.1</a></li>
<li><a href="#">Link 3.2</a></li>
<li><a href="#">Link 3.3</a></li>
<li><a href="#">Link 3.4</a></li>
<li><a href="#">Link 3.5</a></li>
</ul>
</li>
<li><a href="#">Link 4</a></li>
<li><a href="#">Link 5</a></li>
<li><a href="#">Link 6</a></li>
<li><a href="#">Link 7</a>
<ul>
<li><a href="#">Link 7.1</a></li>
<li><a href="#">Link 7.2</a></li>
<li><a href="#">Link 7.3</a>
<ul>
<li><a href="#">Link 7.3.1</a></li>
<li><a href="#">Link 7.3.2</a></li>
<li><a href="#">Link 7.3.3</a></li>
<li><a href="#">Link 7.3.4</a></li>
<li><a href="#">Link 7.3.5</a></li>
</ul>
</li>
<li><a href="#">Link 7.4</a></li>
<li><a href="#">Link 7.5</a></li>
</ul>
</li>
<li><a href="#">Link 8</a></li>
</ul>
</nav>
</div>
</header>
关于html - 仅在由 flex-wrap :wrap 创建的 'second row' 中对齐 flex 元素,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/46237362/
前言: 有时候,一个数据库有多个帐号,包括数据库管理员,开发人员,运维支撑人员等,可能有很多帐号都有比较大的权限,例如DDL操作权限(创建,修改,删除存储过程,创建,修改,删除表等),账户多了,管理
所以我用 Create React App 创建并设置了一个大型 React 应用程序。最近我们开始使用 Storybook 来处理和创建组件。它很棒。但是,当我们尝试运行或构建应用程序时,我们不断遇
遵循我正在创建的控件的代码片段。这个控件用在不同的地方,变量也不同。 我正在尝试编写指令来清理代码,但在 {{}} 附近插入值时出现解析错误。 刚接触 Angular ,无法确定我错过了什么。请帮忙。
我正在尝试创建一个 image/jpeg jax-rs 提供程序类,它为我的基于 post rest 的 Web 服务创建一个图像。我无法制定请求来测试以下内容,最简单的测试方法是什么? @POST
我一直在 Windows 10 的模拟器中练习 c。后来我改用dev C++ IDE。当我在 C 中使用 FILE 时。创建的文件的名称为 test.txt ,而我给出了其他名称。请帮助解决它。 下面
当我们创建自定义 View 时,我们将 View 文件的所有者设置为自定义类,并使用 initWithFrame 或 initWithCode 对其进行实例化。 当我们创建 customUITable
我正在尝试为函数 * Producer 创建一个线程,但用于创建线程的行显示错误。我为这句话加了星标,但我无法弄清楚它出了什么问题...... #include #include #include
今天在做项目时,遇到了需要创建JavaScript对象的情况。所以Bing了一篇老外写的关于3种创建JavaScript对象的文章,看后跟着打了一遍代码。感觉方法挺好的,在这里与大家分享一下。 &
我正在阅读将查询字符串传递给 Amazon 的 S3 以进行身份验证的文档,但似乎无法理解 StringToSign 的创建和使用方式。我正在寻找一个具体示例来说明 (1) 如何构造 String
前言:我对 C# 中任务的底层实现不太了解,只了解它们的用法。为我在下面屠宰的任何东西道歉: 对于“我怎样才能开始一项任务但不等待它?”这个问题,我找不到一个好的答案。在 C# 中。更具体地说,即使任
我有一个由一些复杂的表达式生成的 ILookup。假设这是按姓氏查找人。 (在我们简单的世界模型中,姓氏在家庭中是唯一的) ILookup families; 现在我有两个对如何构建感兴趣的查询。 首
我试图创建一个 MSI,其中包含 和 exe。在 WIX 中使用了捆绑选项。这样做时出错。有人可以帮我解决这个问题。下面是代码: 错误 error LGH
在 Yii 中,Create 和 Update 通常使用相同的形式。因此,如果我在创建期间有电子邮件、密码、...other_fields...等字段,但我不想在更新期间专门显示电子邮件和密码字段,但
上周我一直在努力创建一个给定一行和一列的 QModelIndex。 或者,我会满足于在已经存在的 QModelIndex 中更改 row() 的值。 任何帮助,将不胜感激。 编辑: QModelInd
出于某种原因,这不起作用: const char * str_reset_command = "\r\nReset"; const char * str_config_command = "\r\nC
现在,我有以下由 original.df %.% group_by(Category) %.% tally() %.% arrange(desc(n)) 创建的 data.frame。 DF 5),
在今天之前,我使用/etc/vim/vimrc来配置我的vim设置。今天,我想到了创建.vimrc文件。所以,我用 touch .vimrc cat /etc/vim/vimrc > .vimrc 所
我可以创建一个 MKAnnotation,还是只读的?我有坐标,但我发现使用 setCooperative 手动创建 MKAnnotation 并不容易。 想法? 最佳答案 MKAnnotation
在以下代码中,第一个日志语句按预期显示小数,但第二个日志语句记录 NULL。我做错了什么? NSDictionary *entry = [[NSDictionary alloc] initWithOb
我正在使用与此类似的代码动态添加到数组; $arrayF[$f+1][$y][$x+1] = $value+1; 但是我在错误报告中收到了这个: undefined offset :1 问题:尝试创
我是一名优秀的程序员,十分优秀!