matchesSelector及低版本IE中对该方法的实现
matchesSelector用来匹配dom元素是否匹配某css selector。它为一些高级方法的实现提供了基础支持,比如事件代理,parent, closest等。
W3C在2006年就提出了该方法草案,Firefox和Safari相继实现,比如
<div id="wraper" class="item"></div>
<script>
wraper.mozMatchesSelector('div') // true 标签选择器
wraper.mozMatchesSelector('#wraper') // true id选择器
wraper.mozMatchesSelector('.item') // true 类选择器
</script>
目前除IE6-IE8,Firefox/Chrome/Safari/Opera/IE 的最新版本均已实现,但方法都带上了各自的前缀
Chrome/Safari
Firefox
IE9+
可以用特性监测来获取一个统一接口API。如下
var matchesSelector = function() {
var body = document.body
return body.webkitMatchesSelector || body.msMatchesSelector || body.mozMatchesSelector || body.oMatchesSelector
}()
有几个细节
1. 优先使用body.webkitMatchesSelector webkit内核占有率最高,尤其国内国产浏览器的高速引擎是webkit
2. 这里没有优选获取body.matchesSelector,是因为该方法迄今尚未标准化
3. 2013年2月Opera放弃Presto转向Webkit,因此把body.oMatchesSelector放在了最后以兼容老版本的Opera
对于低版本的IE,如何实现该方法吗? 首先需要实现一个基本的CSS选择器,这里提供了一个常用选择器(id,class,tagName,attribute)的实现。
两种情况
1. 对于已经存在于页面里的DOM元素
function matches(el, selector) {
var parent = el.parentNode
var match = query(selector, parent)
var len = match.length
if (len) {
while (len--) {
if (match[len] == el) {
return true
}
}
return false
} else {
return false
}
}
存在于页面的DOM元素,必定有parentNode,紧接着在父节点里查找指定的selector,如果不存在返回false,如果存在还有过滤下,如果匹配的元素和传入的el是同一个元素则返回true。
2. 对于动态创建的元素,尚未添加到页面中
function matches(el, selector) {
var tempParent = document.createElement('div')
tempParent.appendChild(el)
match = query(selector, tempParent)
tempParent.removeChild(el)
return !!match.length
} var pp = document.createElement('p')
pp.id = 'pp'
pp.className = 'pp1'
pp.setAttribute('data-info', 'Jack')
pp.innerHTML = 'test' matches(pp, 'p') // true
matches(pp, '#pp') // true
matches(pp, '.pp1') // true
matches(pp, '[data-info=jack]') // true
此时该元素师没有父元素的,这里创建了一个临时的父元素,添加子元素后再把它删掉。剩余思路同上。
两种情况合并一起就完成了对IE9-版本浏览器的支持
function matches(el, selector) {
var parent = el.parentNode
var match = query(selector, parent)
var len = match.length if (parent) {
if (len) {
while (len--) {
if (match[len] == el) {
return true
}
}
return false
} else {
return false
}
} else {
var parent = document.createElement('div')
parent.appendChild(el)
match = query(selector, parent)
parent.removeChild(el)
return !!match.length
}
}
最后是一个完成版本
var matchesSelector = function() {
var body = document.body
var w3cMatches = body.webkitMatchesSelector || body.msMatchesSelector || body.mozMatchesSelector || body.oMatchesSelector function matches(el, selector) {
return w3cMatches.call(el, selector)
} function lowIEMatches(el, selector) {
var parent = el.parentNode
var match = query(selector, parent)
var len = match.length if (parent) {
if (len) {
while (len--) {
if (match[len] == el) {
return true
}
}
return false
} else {
return false
}
} else {
var parent = document.createElement('div')
parent.appendChild(el)
match = query(selector, parent)
parent.removeChild(el)
return !!match.length
}
} return w3cMatches ? matches : lowIEMatches
}()
相关:
http://dev.w3.org/2006/webapi/selectors-api2/#matchtesting
https://developer.mozilla.org/zh-CN/docs/Web/API/Element.matches
http://msdn.microsoft.com/en-us/library/ie/ff975201(v=vs.85).aspx
matchesSelector及低版本IE中对该方法的实现的更多相关文章
- Android 低版本sdk中没有getSupportedPreviewSizes和getSupportedPictureSizes函数怎么办?
在做camera和SurfaceView做摄像头程序时,需要获取camera支持的相片大小,在低版本sdk中没有getSupportedPictureSizes函数,怎么办呢,请参阅下面的关键代码: ...
- popstate事件在低版本webkit中的调用
popstate是H5的history系列中的事件,但是在低版本的webkit中会自动触发.H5中的history api是不会使页面发生跳转的,只是操作地址栏和响应的state属性而已,而且是手动操 ...
- js动态加载activeX控件在IE11与低版本IE中的差异
由于IE11更加遵循W3C规范,所以IE11与低版本IE在加载activeX时有差别. 1.IE11中动态加载activeX的顺序 var objectTag = document.createEle ...
- 高版本 MySQL 导出的脚本到低版本 MySQL 中执行时报错
导入 MySQL 脚本时报错:[ERR] 1273 - Unknown collation: 'utf8mb4_0900_ai_ci'低版本还不支持 utfmb4 这个字符集 解决方法:将 sql 脚 ...
- js中的bind方法的实现方法
js中目前我遇见的改变作用域的5中方法:call, apply, eval, with, bind. var obj = { color: 'green' } function demo () { c ...
- 解决backgroud:transparent在低版本浏览器中的bug
今天在html页面上定义了一个button和一个div,大小相同,button使用绝对定位,覆盖在div上面一层,同时样式设置背景透明(background:transparent). 这样就可以在看 ...
- SQL Server 临时禁用和启用所有外键约束(高版本向低版本迁移数据)
--获得禁用所有外键约束的语句 select 'ALTER TABLE [' + b.name + '] NOCHECK CONSTRAINT ' + a.name +';' as 禁用约束 from ...
- Highcharts 在低版本 IE 上使用注意事项及个人总结
很多人经常遇到图表在主流浏览器上运行正常,在低版本IE(包括IE6.IE7.IE8等)下运行出错(图表显示不出来或显示不正常)的情况,这不是兼容性问题,而是 IE 浏览器自身的一些限制,我们只需要注意 ...
- Highcharts 在低版本 IE 上使用注意事项
来源:https://segmentfault.com/a/1190000004272693 很多人经常遇到图表在主流浏览器上运行正常,在低版本IE(包括IE6.IE7.IE8等)下运行出错(图表显示 ...
随机推荐
- 搜索 + 剪枝 --- POJ 1101 : Sticks
Sticks Problem's Link: http://poj.org/problem?id=1011 Mean: http://poj.org/problem?id=1011&lan ...
- asp.net Get和Post传参和接收参数
asp.netGet和Post传参和接收参数 Get请求: 对于传参:test.aspx?name=%e5%bc%a0%e4%b8%89 接收参数的方法: Request.QueryString[&q ...
- BI之SSAS完整实战教程7 -- 设计维度、细化维度中 :浏览维度,细化维度
上篇文章我们已经将Dim Geography维度设计好. 若要查看维度的成员, AS需要接收该维度的详细信息(包括已创建的特性.成员属性以及多级层次结构), 通过XMLA与AS的实例进行通信. 今天我 ...
- ActiveReports 报表应用教程 (8)---交互式报表之动态过滤
用户可以使用ActiveReports参数 (Parameters)集合把数据提供给报表中的文本框或图表,也可以选择数据的一个子集显示到报表的特定区域,或者是把数据从主报表象子报表传递.用户可以通过三 ...
- jQuery pgwslideshow 空间相册
一个响应式相册插件,你可以自定义幻灯片最大高度,滑动效果,是否显示控制按钮,自动轮播或间隔时间. pgwslideshow相册插件有以下特点 支持响应式 支持桌面和移动设备 代码简单 ...
- JavaScript中的null与nudefined
null和undefined 概述 null与undefined都可以表示"没有",含义非常相似.将一个变量赋值为undefined或null,老实说,语法效果几乎没区别. var ...
- viewport的一些事
整理了下viewport的东西,用脑图画了下
- HTML中行内元素的竖直方向的padding和margin是否真的无效
参考资料:Inline elements and padding 今天写一个导航栏时遇到了一个问题:行内元素的padding-top,padding-bottom和margin-top,margin- ...
- 高清SDI编码器|上海视涛科技
SDI编码器(E500)简介 SDI编码器(E500)是上海视涛科技出品的高性能SDI编码产品.该SDI编码器是上海视涛电子完全自主研发,并适用于各种SDI信号的编码采集及网络传输的专用硬件设备.可兼 ...
- Sharepoint学习笔记—习题系列--70-573习题解析 -(Q45-Q47)
Question45You create and deploy a custom Web Part.You add the Web Part to a page and receive a run-t ...