- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
有一个few好questions此处关于如何确定焦点与文本区域“并发”的位置 onblur
。
但是我还没有找到一个好的跨浏览器方法来确定哪个 anchor 标记被点击导致文本区域触发onblur
、setTimeout
或不触发。 document.activeElement
看起来很有希望,但是,答案似乎恰恰相反,如果没有 setTimeout
,activeElement
是不可靠的。在某些浏览器中,我不断收到作为 activeElement
返回的 body
。
例如: jsFiddle-ige #1 :
HTML
<form>
<input onblur="blurHandler();" type="text" id="spam1"
value="immediate blur check">
<input onblur="blurHandlerTimeout();" type="text" id="spam2"
value="delayed blur check">
<a href="#" id="spam3">X</a>
<br>
</form>
<br>
<hr>
<br>
<div id="logs"></div>
JavaScript
var logs = document.getElementById('logs');
function blurHandler() {
logit(document.activeElement.outerHTML.substr(0, 80));
}
function blurHandlerTimeout() {
setTimeout(function () {
logit(document.activeElement.outerHTML.substr(0, 80));
}, 10);
}
function logit(msg) {
try {
var e = document.createTextNode(msg), // probably a better way, but this does allow html as text
f = document.createElement('div');
logs.insertBefore(e, logs.firstChild);
logs.insertBefore(f, logs.firstChild);
} catch (err) {
alert(err);
}
}
每次出现以下情况时都会出现立即模糊检查文本框的模糊主体元素:
将焦点设置为延迟模糊复选框并单击/按 Tab 键进入 anchor 可以得到:
IE8 每次都会为我提供每个文本框、延迟处理程序或否的 anchor 。
因此,诚然,有一些方法可以让 anchor 在共享范围级别(例如全局)设置一个 bool 值,并从模糊事件查询中设置一个 bool 值 setTimeout 来查看 anchor [最近]是否获得焦点,但是伙计天哪,这太糟糕了。
也就是说,我做到了,无论给予还是接受,在这里:jsFiddle-ige #2似乎在所有四个中都工作得很好,尽管我担心它会变得疯狂。
有更好的方法吗?我想 jQuery 很好,尽管我更喜欢干净的 JavaScript 解决方案——也就是说,干净的 jQuery 解决方案比复杂的 JavaScript 修复更好。
最佳答案
document.activeElement
的延迟检查只要您在 anchor 标记上指定 tabindex
属性,就可以在所有浏览器中使用。默认情况下,a
没有 Tab 键顺序,因此我认为那些能够在没有该属性的情况下“聚焦”a
的浏览器行为不当。
根据 HTML5 spec :
The tabindex content attribute allows authors to control whether an element is supposed to be focusable, whether it is supposed to be reachable using sequential focus navigation, and what is to be the relative order of the element for the purposes of sequential focus navigation.
(强调我的)
<form>
<input onblur="blurHandler();" type="text" id="spam1"
value="immediate blur check">
<input onblur="blurHandlerTimeout();" type="text" id="spam2"
value="delayed blur check">
<a href="#" id="spam3" tabindex='1'>X</a>
<br>
</form>
<br>
<hr>
<br>
<div id="logs"></div>
更新了 fiddle : http://jsfiddle.net/Y5kcp/4/
在 IE8/9、FF 18.0.1、Chrome 24.0.1312.56 m、Safari 5.17 中测试
这纯粹是猜测,但也许 IE 表现良好是因为 HTML4 spec for tabindex
没有提到“可聚焦性”作为一项功能:
This attribute specifies the position of the current element in the tabbing order for the current document.
在这种情况下,也许遵守 HTML 4 规范的浏览器可以允许 anchor 标记在有或没有 tabindex 属性的情况下具有焦点。
还值得注意的是,document.activeElement
是一项专有的 IE4 功能(请参阅 MDN 文章中有关 document.activeElement
的注释)。也许这就是为什么它可以在 Internet Explorer 中正常运行而不会超时。
关于javascript - 跨浏览器方法确定选择的 anchor 标记会导致文本区域模糊,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14653381/
是否有某种方法可以使用 JPA 或 Hibernate Crtiteria API 来表示这种 SQL?或者我应该将其作为 native 执行吗? SELECT A.X FROM (SELECT X,
在查询中, select id,name,feature,marks from (....) 我想删除其 id 在另一个 select 语句中存在的那些。 从 (...) 中选择 id 我是 sql
我想响应用户在 select 元素中选择一个项目。然而这个 jQuery: $('#platypusDropDown').select(function () { alert('You sel
这个问题在这里已经有了答案: SQL select only rows with max value on a column [duplicate] (27 个回答) 关闭8年前。 我正在学习 SQL
This question already has answers here: “Notice: Undefined variable”, “Notice: Undefined index”, and
我在 php 脚本中调用 SQL。有时“DE”中没有值,如果是这种情况我想从“EN”中获取值 应该是这样的,但不是这样的 IF (EXISTS (SELECT epf_application_deta
这可能是一个奇怪的问题,但不知道如何研究它。执行以下查询时: SELECT Foo.col1, Foo.col2, Foo.col3 FROM Foo INNER JOIN Bar ON
如何在使用 Camera.DestinationType.FILE_URI. 时在 phonegap camera API 中同时选择或拾取多个图像我能够一次只选择一张图像。我可以使用 this 在
这是一个纯粹的学术问题。这两个陈述实际上是否相同? IF EXISTS (SELECT TOP 1 1 FROM Table1) SELECT 1 ELSE SELECT 0 相对 IF EXIS
我使用 JSoup 来解析 HTML 响应。我有多个 Div 标签。我必须根据 ID 选择 Div 标签。 我的伪代码是这样的 Document divTag = Jsoup.connect(link
我正在处理一个具有多个选择框的表单。当用户从 selectbox1 中选择一个选项时,我需要 selectbox2 active 的另一个值。同样,当他选择 selectbox2 的另一个值时,我需要
Acme Inc. Christa Woods Charlotte Freeman Jeffrey Walton Ella Hubbard Se
我有一个login.html其中form定义如下: First Initial Plus Last Name : 我的do_authorize如下: "; pri
$.get( 'http://www.ufilme.ro/api/load/maron_online/470', function(data
我有一个下拉列表“磅”、“克”、“千克”和“盎司”。我想要这样一种情况,当我选择 gram 来执行一个函数时,当我在输入字段中输入一个值时,当我选择 pounds 时,我想要另一个函数来执行时我在输入
我有一个 GLSL 着色器,它从输入纹理的 channel 之一(例如 R)读取,然后写入输出纹理中的同一 channel 。该 channel 必须由用户选择。 我现在能想到的就是使用一个 int
我想根据下拉列表中的选定值生成输入文本框。 Options 2 3 4 5 就在这个选择框之后,一些输入字段应该按照选定的数字出现。 最佳答案 我建议您使用响应式(Reac
我是 SQL 新手,我想问一下如何根据首选项和分组选择条目。 +----------+----------+------+ | ENTRY_ID | ROUTE_ID | TYPE | +------
我有以下表结构: CREATE TABLE [dbo].[UTS_USERCLIENT_MAPPING_USER_LIST] ( [MAPPING_ID] [int] IDENTITY(1,1
我在移除不必要的床单时遇到了问题。我查看了不同的论坛并将不同的解决方案混合在一起。 此宏删除工作表(第一张工作表除外)。 Sub wrong() Dim sht As Object Applicati
我是一名优秀的程序员,十分优秀!