- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
所以,我目前正在一个网站上练习网络开发,但遇到了一些小问题。我希望能够单击图像“搜索图标”,然后让我的文本字段滑出,它确实如此,但它没有聚焦并准备好供用户输入。当我添加焦点事件时它起作用了,但它失去了过渡并将我在导航支架中的其他内容推到一边一秒钟,然后又回来了。我很困惑为什么会这样,我希望得到一些帮助来解决我的问题并更好地理解它。
这是我的 HTML:
<header>
<div class="nav-holder">
<nav>
<ul>
<li><a class="active" href="index.html">HOME</a></li>
<li><a href="#">WORK EXPERIENCE <span class="one"></span><span class="two"></span></a>
<ul>
<li><a href="#">WEB DEVELOPEMENT</a></li>
<li><a href="#">IT SUPPORT</a></li>
</ul>
</li>
<li><a href="#">INTRODUCING ME</a></li>
<li><a href="#">CONTACT INFORMATION</a></li>
</ul>
</nav>
<form method="post" action="">
<input id="search-box" type="text" name="search" placeholder="Search...">
</form>
<img id="search-icon" src="img/searchicon.png"/>
<div class="clear"></div>
</div>
</header>
这是我的 CSS:
* {
margin: 0;
padding: 0;
}
.nav-holder {
position: fixed;
top: 0;
background-color: black;
opacity: .8;
max-width: 100vw;
width: 100%;
max-height: 40px;
height: 100%;
overflow: hidden;
z-index: 1;
}
nav {
width: 72vw;
line-height: 28px;
font-size: 12px;
}
.active {
color: lightgrey;
}
nav li {
list-style: none;
float: left;
}
nav a {
text-decoration: none;
padding: 6px 12px;
display: block;
color: dimgrey;
font-family: "Verdana";
}
nav a:hover {
color: lightgrey;
transition: all ease-in-out .3s;
}
nav a:hover .one, nav a:hover .two {
background-color: lightgrey;
transition: all ease-in-out .3s;
}
nav ul ul {
position: fixed;
opacity: 0;
z-index: -1;
visibility: hidden;
background-color: black;
transform: translateY(-2em);
transition: all 0.3s ease-in-out 0s, visibility 0s linear 0.3s, z-index 0s linear 0.01s;
}
nav ul li:hover > a {
color: lightgrey;
}
nav ul li:hover .one, nav ul li:hover .two {
background-color: lightgrey;
}
nav ul li:hover ul {
visibility: visible;
opacity: 1;
z-index: 2;
transform: translateY(0%);
transition-delay: 0s, 0s, 0.3s;
}
nav ul li ul li {
float: none;
}
.one {
display: inline-block;
background-color: dimgrey;
height: 1px;
width: 7px;
transform: rotate(55deg);
margin-left: -3px;
margin-bottom: 4px;
}
.two {
display: inline-block;
background-color: dimgrey;
height: 1px;
width: 7px;
transform: rotate(125deg);
margin-left: -3.2px;
margin-bottom: 4px;
}
#search-icon {
float: right;
max-height: 18px;
height: 100%;
max-width: 18px;
width: 100%;
cursor: pointer;
margin-top: 11px;
margin-right: 7px;
}
#search-box {
width: 200px;
box-sizing: border-box;
transition: all ease-in-out .3s;
position: relative;
float: right;
margin-top: 9px;
margin-right: -200px;
line-height: 22px;
border: none;
outline: none;
background-color: black;
opacity: .8;
}
#search-box:focus {
caret-color: lightgrey;
color: lightgrey;
}
#search-box.active {
margin-right: 0;
}
@-webkit-keyframes autofill {
to {
color: lightgrey;
background: transparent;
}
}
input:-webkit-autofill {
-webkit-animation-name: autofill;
-webkit-animation-fill-mode: both;
}
.clear {
clear: both;
}
这是我的 JQuery:
$(document).ready(function () {
$('html').on('click', function (e) {
if (e.target.id == 'search-icon') {
$('#search-box').toggleClass('active');
$('#search-box').focus();
}
else if (e.target.id == 'search-box') {
$('#search-box').focusin();
}
else {
$('#search-box').removeClass('active');
$('#search-box').val("");
}
});
});
感谢您的提前协助!
最佳答案
从 .nav-holder
中移除 overflow:hidden。您需要处理导航栏的布局以提高响应能力。
$(document).ready(function() {
$('html').on('click', function(e) {
if (e.target.id == 'search-icon') {
$('#search-box').toggleClass('active');
$('#search-box').focus();
} else if (e.target.id == 'search-box') {
$('#search-box').focusin();
} else {
$('#search-box').removeClass('active');
$('#search-box').val("");
}
});
});
* {
margin: 0;
padding: 0;
}
.nav-holder {
position: fixed;
top: 0;
background-color: black;
opacity: .8;
max-width: 100vw;
width: 100%;
max-height: 40px;
height: 100%;
z-index: 1;
}
nav {
width: 72vw;
line-height: 28px;
font-size: 12px;
}
.active {
color: lightgrey;
}
nav li {
list-style: none;
float: left;
}
nav a {
text-decoration: none;
padding: 6px 12px;
display: block;
color: dimgrey;
font-family: "Verdana";
}
nav a:hover {
color: lightgrey;
transition: all ease-in-out .3s;
}
nav a:hover .one,
nav a:hover .two {
background-color: lightgrey;
transition: all ease-in-out .3s;
}
nav ul ul {
position: fixed;
opacity: 0;
z-index: -1;
visibility: hidden;
background-color: black;
transform: translateY(-2em);
transition: all 0.3s ease-in-out 0s, visibility 0s linear 0.3s, z-index 0s linear 0.01s;
}
nav ul li:hover>a {
color: lightgrey;
}
nav ul li:hover .one,
nav ul li:hover .two {
background-color: lightgrey;
}
nav ul li:hover ul {
visibility: visible;
opacity: 1;
z-index: 2;
transform: translateY(0%);
transition-delay: 0s, 0s, 0.3s;
}
nav ul li ul li {
float: none;
}
.one {
display: inline-block;
background-color: dimgrey;
height: 1px;
width: 7px;
transform: rotate(55deg);
margin-left: -3px;
margin-bottom: 4px;
}
.two {
display: inline-block;
background-color: dimgrey;
height: 1px;
width: 7px;
transform: rotate(125deg);
margin-left: -3.2px;
margin-bottom: 4px;
}
#search-icon {
float: right;
max-height: 18px;
height: 100%;
max-width: 18px;
width: 100%;
cursor: pointer;
margin-top: 11px;
margin-right: 7px;
}
#search-box {
width: 200px;
box-sizing: border-box;
transition: all ease-in-out .3s;
position: relative;
float: right;
margin-top: 9px;
margin-right: -200px;
line-height: 22px;
border: none;
outline: none;
background-color: black;
opacity: .8;
}
#search-box:focus {
caret-color: lightgrey;
color: lightgrey;
}
#search-box.active {
margin-right: 0;
}
@-webkit-keyframes autofill {
to {
color: lightgrey;
background: transparent;
}
}
input:-webkit-autofill {
-webkit-animation-name: autofill;
-webkit-animation-fill-mode: both;
}
.clear {
clear: both;
}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<header>
<div class="nav-holder">
<nav>
<ul>
<li><a class="active" href="index.html">HOME</a></li>
<li><a href="#">WORK EXPERIENCE <span class="one"></span><span class="two"></span></a>
<ul>
<li><a href="#">WEB DEVELOPEMENT</a></li>
<li><a href="#">IT SUPPORT</a></li>
</ul>
</li>
<li><a href="#">INTRODUCING ME</a></li>
<li><a href="#">CONTACT INFORMATION</a></li>
</ul>
</nav>
<form method="post" action="">
<input id="search-box" type="text" name="search" placeholder="Search...">
</form>
<img id="search-icon" src="http://placehold.it/50/00ff00" />
<div class="clear"></div>
</div>
</header>
关于jquery - 滑出 TextField 焦点推送内容并丢失转换,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/45582683/
我需要一些帮助。这都是关于选项卡索引的。我有一个使用 document.getElementById("name").focus(); 的 JavaScript,其中 id="name"的 textb
这是我的第一篇文章,如果您想了解更多信息,请告诉我! 我正在使用选择列表和 jQuery Accordion 。当用户从列表中选择一个值时,它会使用 activate 方法打开折叠面板的相关部分。 除
JQM 1.3.2/ASP.NET MVC 4 当选择一个值时,焦点没有正确设置到输入字段,我错过了什么? 周围的典型 jqm-shadow 没有从选择中移除,输入得到阴影效果,但光标没有设置到输入字
我正在为 Android 开发一个播放列表应用程序,它有一个包含歌曲名称 (TextView) 作为其列表项的 ListView。 随着歌曲的播放,我想突出显示 ListView 中的项目,直到歌曲结
我在这里不知所措,以前从来没有遇到过这个问题。 我无法让 focus() 在任何浏览器中工作。我正在使用 jquery,甚至不能让它与标准的 javascript 一起工作。我也尝试添加超时但仍然没有
登录后我有一个文本字段。登录后光标将自动聚焦在该文本字段上。如何验证该文本字段上是否存在光标/焦点? 文本框的HTML代码如下: 最佳答案 您也可以尝试直接的 webdriver 方法: drive
我有一个框架和一个面板。我永久删除面板并添加另一个面板。添加新面板后,我需要 JTextField 来获得焦点。我该怎么做? 我尝试了 panel.requestFocus() 方法,但没有成功。 示
这个问题在这里已经有了答案: 关闭 13 年前。 Possible Duplicate: Trouble with jquery lavalamp 出于某种原因,无论我点击哪个链接,我的背景颜色都会
在我的表单验证中,在提交时,我正在验证表单,并找到未填充的元素并使用此函数进行聚焦:工作正常 switch (tagName) { case 'TEXT': if (!actualVa
我最近构建了一个 JS/CSS 模态系统。该元素使用的是 Bootstrap 模式,但通过在其中放置无法滚动或无法正确聚焦在移动设备上的表单和大量内容,将其推向了极限。 可以触发模态系统here单击大
我正在建立一个网站,但我想将图片放在背景中,但我无法将其放在我想要的位置。 我希望网页上图像的“焦点”位于图像中心几像素处。宽度我都能看出来,但是高度没有。 图像分辨率为“5760x3840px”。
这个问题在这里已经有了答案: using :focus pseudo class on li or other element else than a,input,button, etc (2 个
每当我创建编辑器的另一个实例(在我的例子中,通过 onkeypress 事件),我就会失去对创建新编辑器时正在输入的编辑器的关注。我怎样才能防止所有编辑都失去对任何事件的关注? 最佳答案 为此,Qui
我试图将焦点放在一个字段上,更改文本的颜色,但无论我尝试什么:它都不起作用。以下是 HTML: .register-section input:focus + .register-section la
我已经为微调器选择的变化设置了一个监听器。在监听器中,我想关注一个 EditText 字段。我使用了以下代码: text_other_msg.setFocusable(true); 它不起作用。我还尝
我在表单屏幕上有几个 UITextField 输入,其中一些有一个数字键盘显示,通过自定义弹出窗口显示。当用户在字段中前进时,我们会根据需要关闭或打开弹出窗口。在 iOS 11 中,似乎“第一响应者”
我在 jQueryUI 中输入焦点时遇到问题。我在按钮上使用了 hover() 方法并且它正在工作,但是输入上的 focus() 不起作用。我不知道为什么。这是代码和 fiddle $(documen
有没有办法在自动对焦完成后随时获取对焦点? 在 Apple 的示例代码中,他们使用: - (void)subjectAreaDidChange:(NSNotification *)notifi
如果我的焦点不在 textField 上,如何移除 NSTextField 上的焦点? 我有一个 NSTextField,我设置了操作:编辑结束时发送。单击 textField 后,当我单击 View
如何通过 jQuery 实现这一点? 当用户单击表单中的任何输入时,它就会获得焦点。当用户从任何输入中单击表单外时,它会变得模糊,但是,在表单本身的输入之间进行 Tab 键切换之间不会触发模糊。 对于
我是一名优秀的程序员,十分优秀!