- 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/
在使用 GDI 进行图形处理的传统 Windows 程序中,您必须担心只绘制需要重绘的窗口区域;这是“更新矩形”,可以通过 PAINTSTRUCT.rcPaint 或通过调用 GetUpdateRec
我对 TFS 中的所有内容感到困惑。有人可以解释一下所有这些是如何组合在一起的吗? 团队项目合集 团队项目 团队 地区 迭代 来自 this page,我认为一个(团队)项目集合可以包含多个(团队)项
这对我来说根本没有意义。创建新的 API 网关时,您可以指定它是区域优化的还是边缘优化的。但话又说回来,当您为 API Gateway 创建自定义域名时,您可以在两者之间进行选择。 最糟糕的是,您可以
我有一个工作表,其中包含我想循环遍历的许多不同区域。我将进行一些计算,并认为它比在列中逐个单元格地更快/更有效。 我尝试了一些不同的东西,但不知道如何跳到下一个区域。我已经发表了一些评论,最有希望的是
最近迁移到 TFS 2010 后,我想知道对于区域而言,最佳或最广泛接受的定义或配置是什么? 我能在网上找到的唯一有用的文章是 this one并且是我认为是正确的。然而,这让我开始思考是否以下任何一
我在“北欧”有一个存储帐户,现在我想使用生命周期管理将冷 blob 移动到存档层。 但是我每次尝试都会遇到以下失败:无法为存储帐户“myStorageAccount”添加生命周期管理规则。错误:管理策
我正在开发一个项目,您在扫描仪中输入州的缩写,然后程序会告诉您该州位于美国的哪个地区。我认为我的大部分代码都是正确的,但我有以前从未使用过 switch。 我已经将我的工作改进为一个错误,即我的第一个
我正在尝试学习 AngularJS,我想我有一个架构问题。 如果我想开始开发一个应用程序,比方说,比如 youtube,我如何在“区域”(比如 Marionette)中组织页面?我的意思是:顶部导航栏
我正在制作一个动态内存分配器,当我释放其中的一部分时,我需要检查我传递给函数的指针实际上是否在该区域内。我有一个指向 malloc 区域开头的指针 typedef unsigned char byte
有时我想看看 到底在哪里页面上图片上的标签。 在 Javascript 中有没有办法改变颜色或隐藏与区域标签对应的图像部分? 最佳答案 也许您正在寻找类似 mapper.js 的内容.它允许您在鼠标
我有一个使用 D3 js 创建的时间序列图表。我想为特定时间间隔添加高亮区域,以显示在该特定时间发生的特定事件(会有不同类型的事件,因此每个高亮标记将根据其类型具有不同的颜色)。我希望这个突出显示区域
我正在尝试创建网站的密码保护区。我想通过检查 MySql 表中的用户名和密码来允许访问,然后启动一个 session 并允许在 session 处于事件状态时访问多个页面。如果有人尝试直接访问这些页面
在 ScrollView 中我添加了几个按钮。正如您在图片中看到的,2 个按钮完全可见,第三个按钮半可见。当我向右滚动看到第三个时;1-如果滚动条很短,则它会滚动回到第一个位置。2- 如果滚动足够则显
我正在开发我的第一个 spritekit 应用程序,并且有一个关于如何处理我想到的事情的快速问题。我正在制作一个我想要的棋盘游戏原型(prototype),并希望在 iOS map 中进行一些集思广益
在我的 C# 程序中,我收到这样的日期和时间:DateTime.Now 我得到:19/09/2010 20:10:30 因为我的地区是:希伯来语(以色列) 但是如果我将我的程序安装在区域为 Engli
有时我在 Visual Studio 的源文件中运行(在我的例子中是 2010),我看到很多区域,我必须点击 + 号才能一个一个地打开它们! 是否有任何快捷方式或菜单选项可以使这对我来说更容易,并且对
关闭。这个问题是opinion-based .它目前不接受答案。 想要改进这个问题? 更新问题,以便 editing this post 可以用事实和引用来回答它. 关闭 7 年前。 Improve
我正在寻找二维数据中的峰值区域(如果您愿意,灰度图像或二维景观,通过霍夫变换创建)。 峰值区域是指局部最大峰值,但不是单个点而是周围的一部分strong>contributing region 随之而
我希望能够将任何字符或字符串转换为形状或区域,以便我可以按照我喜欢的任何大小、样式、效果等来绘制该字符。 更具体地说,我将使用视差绘制它,以便它仅在特定角度清晰定义(这就是为什么我不能使用 html
我非常喜欢数学(或者你们大多数人会说的“数学”!),但我还没有达到知道这个问题答案的程度。我有一个主圆,它可以在显示器上的任何 x 和 y 处有一个中心点。其他圆圈将随意在显示器周围移动,但在任何给定
我是一名优秀的程序员,十分优秀!