- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在开发 Web 应用程序,并遇到了文本框在键入时失去焦点的问题。
具体来说,让我解释一下这是如何发生的:
注意:文本框是可编辑的下拉列表。
下面是用于下拉菜单的代码。
<input type="text" id="placeDeathState" name="placeDeathState" size="3" maxlength="25"
value="" style="vertical-align:top; margin:2px 0px 0px 0px; border:0px;"
onfocus="focusAutoSelect(document.getElementById('placeDeathState'), 2, '', '', '');"
onblur="this.autoSelect.hideComboList();">
更新1:focusAutoSelect() 函数的代码
function focusAutoSelect(obj, col, tgts, cols, scripts) {
if (!obj.autoSelect)
obj.autoSelect = new AutoSelectCombo(obj.id, col, tgts, cols, scripts);
}
更新2:
AutoSelectCombo 对象:
它的作用如下:
这是 AutoSelectCombo 对象。虽然它一开始是作为线性自动选择,现在是通过过滤选择。任何事物在此框中键入的内容将用于过滤选项列表仅包含所键入文本的项目。
function AutoSelectCombo(id, col, tgts, cols, scrs) {
this.editFocused= false;
this.selFocused = false;
this.timer = null;
this.column = col;
this.quicksel = false;
this.quickstr = "";
this.targets = new Array();
this.columns = new Array();
this.scripts = scrs.split("#");
this.gotChar = false;
this.ascDiv = document.getElementById(id+"div");
this.ascText = document.getElementById(id);
this.ascImage = document.getElementById(id+"btn");
this.ascEditBtn = document.getElementById(id+"edit");
this.ascSDiv = document.getElementById(id+"combo");
this.ascSelect = document.getElementById(id+"select");
this.ascFrm = document.getElementById(id+"ifrm");
this.options = new Array();
this.lastLen = this.ascText.value.length;
this.maxItems = 10;
this.blurClosed = false;
this.selIndex=0;
if ((tgts!=null) && (tgts!="")) {
this.targets = tgts.split("|");
this.columns = cols.split("|");
}
if (this.ascText.readOnly == true)
this.quicksel = true;
for (; this.selIndex<this.ascSelect.length; this.selIndex++)
if (this.ascSelect.options[this.selIndex].value == this.ascSelect.value)
break;
if (this.selIndex >= this.ascSelect.length)
this.selIndex = -1;
if (this.ascDiv)
this.ascDiv.autoSelect = this;
if (this.ascText)
this.ascText.autoSelect = this;
if (this.ascImage)
this.ascImage.autoSelect = this;
if (this.ascEditBtn)
this.ascEditBtn.autoSelect = this;
if (this.ascSDiv)
this.ascSDiv.autoSelect = this;
if (this.ascSelect)
this.ascSelect.autoSelect = this;
this.ascText.oldOnFocus = this.ascText.onfocus;
this.ascText.onfocus = function(evt) {
if (!evt)
evt = window.event;
this.autoSelect.editFocused = true;
if (this.autoSelect.ascText.oldOnFocus)
this.autoSelect.ascText.oldOnFocus.call(this.autoSelect.ascText);
}
this.ascText.oldOnBlur = this.ascText.onblur;
this.ascText.onblur = function(evt) {
if (!evt)
evt = window.event;
this.autoSelect.editFocused = false;
this.autoSelect.handleBlur(evt);
if (this.autoSelect.ascText.oldOnBlur)
this.autoSelect.ascText.oldOnBlur.call(this.autoSelect.ascText);
}
this.ascText.oldOnKeyDown = this.ascText.onkeydown;
this.ascText.onkeydown = function(evt) {
if (!evt)
evt = window.event;
this.autoSelect.handleComboKeyDown(evt);
if (this.autoSelect.ascText.oldOnKeyDown)
this.autoSelect.ascText.oldOnKeyDown.call(this.autoSelect.ascText);
}
this.ascText.oldOnKeyPress = this.ascText.onkeypress;
this.ascText.onkeypress = function(evt) {
if (!evt)
evt = window.event;
this.autoSelect.handleComboKeyPress(evt);
if (this.autoSelect.ascText.oldOnKeyPress)
this.autoSelect.ascText.oldOnKeyPress.call(this.autoSelect.ascText);
}
this.ascText.oldOnKeyUp = this.ascText.onkeyup;
this.ascText.onkeyup = function(evt) {
if (!evt) {
evt = window.event;
}
this.autoSelect.handleComboKeyUp(evt);
if (this.autoSelect.ascText.oldOnKeyUp) {
this.autoSelect.ascText.oldOnKeyUp.call(this.autoSelect.ascText);
}
}
this.ascImage.oldOnClick = this.ascImage.onclick;
this.ascImage.onclick = function(evt) {
if (!evt) {
evt = window.event;
}
this.autoSelect.editFocused = true;
this.autoSelect.toggleComboList();
this.autoSelect.blurClosed = false;
//if (this.autoSelect.ascImage.oldOnClick)
// this.autoSelect.ascImage.oldOnClick.call(this.autoSelect.ascImage);
}
this.ascSelect.oldOnKeyPress = this.ascSelect.onkeypress;
this.ascSelect.onkeypress = function(evt) {
if (!evt)
evt = window.event;
var keyCode = evt.keyCode ? evt.keyCode : evt.which ? evt.which : evt.charCode;
if (evt.keyCode == 13) {
this.autoSelect.hideComboList();
return false;
}
}
this.ascSelect.oldOnChange = this.ascSelect.onchange;
this.ascSelect.onchange = function(evt) {
if (!evt)
evt = window.event;
this.autoSelect.setComboValue();
// this.autoSelect.hideComboList();
//if (this.autoSelect.ascSelect.oldOnChange)
// this.autoSelect.ascSelect.oldOnChange.call(this.autoSelect.ascSelect);
}
this.ascSelect.oldOnClick = this.ascSelect.onclick;
this.ascSelect.onclick = function(evt) {
if (!evt) {
evt = window.event;
}
this.autoSelect.setComboValue();
//this.autoSelect.ascText.focus();
//this.autoSelect.hideComboList();
for (i=1; i<this.autoSelect.scripts.length; (i=i+1)) {
eval(this.autoSelect.scripts[i]);
}
}
this.ascSelect.oldOnFocus = this.ascSelect.onfocus;
this.ascSelect.onfocus = function(evt) {
if (!evt)
evt = window.event;
this.autoSelect.selFocused = true;
}
this.ascSelect.oldOnBlur = this.ascText.onblur;
this.ascSelect.onblur = function(evt) {
if (!evt)
evt = window.event;
this.autoSelect.selFocused = false;
this.autoSelect.hideComboList();
}
this.duplicateElements();
}
我不知道如何进一步调查以及出了什么问题。
最佳答案
我发现了问题,
问题出在函数 showComboList
上,找到匹配项后,会显示组合列表并获得焦点,结果焦点从输入元素中丢失。
函数内部AutoSelectCombo.prototype.showComboList = function(){
,删除/注释 fs.focus()
行。
您可以开始了。
关于javascript - 文本框在打字时失去焦点,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33800207/
我需要一些帮助。这都是关于选项卡索引的。我有一个使用 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 键切换之间不会触发模糊。 对于
我是一名优秀的程序员,十分优秀!