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中对该方法的实现的更多相关文章

  1. Android 低版本sdk中没有getSupportedPreviewSizes和getSupportedPictureSizes函数怎么办?

    在做camera和SurfaceView做摄像头程序时,需要获取camera支持的相片大小,在低版本sdk中没有getSupportedPictureSizes函数,怎么办呢,请参阅下面的关键代码: ...

  2. popstate事件在低版本webkit中的调用

    popstate是H5的history系列中的事件,但是在低版本的webkit中会自动触发.H5中的history api是不会使页面发生跳转的,只是操作地址栏和响应的state属性而已,而且是手动操 ...

  3. js动态加载activeX控件在IE11与低版本IE中的差异

    由于IE11更加遵循W3C规范,所以IE11与低版本IE在加载activeX时有差别. 1.IE11中动态加载activeX的顺序 var objectTag = document.createEle ...

  4. 高版本 MySQL 导出的脚本到低版本 MySQL 中执行时报错

    导入 MySQL 脚本时报错:[ERR] 1273 - Unknown collation: 'utf8mb4_0900_ai_ci'低版本还不支持 utfmb4 这个字符集 解决方法:将 sql 脚 ...

  5. js中的bind方法的实现方法

    js中目前我遇见的改变作用域的5中方法:call, apply, eval, with, bind. var obj = { color: 'green' } function demo () { c ...

  6. 解决backgroud:transparent在低版本浏览器中的bug

    今天在html页面上定义了一个button和一个div,大小相同,button使用绝对定位,覆盖在div上面一层,同时样式设置背景透明(background:transparent). 这样就可以在看 ...

  7. SQL Server 临时禁用和启用所有外键约束(高版本向低版本迁移数据)

    --获得禁用所有外键约束的语句 select 'ALTER TABLE [' + b.name + '] NOCHECK CONSTRAINT ' + a.name +';' as 禁用约束 from ...

  8. Highcharts 在低版本 IE 上使用注意事项及个人总结

    很多人经常遇到图表在主流浏览器上运行正常,在低版本IE(包括IE6.IE7.IE8等)下运行出错(图表显示不出来或显示不正常)的情况,这不是兼容性问题,而是 IE 浏览器自身的一些限制,我们只需要注意 ...

  9. Highcharts 在低版本 IE 上使用注意事项

    来源:https://segmentfault.com/a/1190000004272693 很多人经常遇到图表在主流浏览器上运行正常,在低版本IE(包括IE6.IE7.IE8等)下运行出错(图表显示 ...

随机推荐

  1. C#反射的应用

    项目框架中有一个很实用的方法,它用来获取客户端post的数据,并自动赋值到对象各属性,这样后台少写了很多代码.但是对于有主表.子表的表单,框架中没有提供自动给子表对象各属性赋值的方法,每次都要写很多代 ...

  2. JavaMail入门第五篇 解析邮件

    上一篇JavaMail入门第四篇 接收邮件中,控制台打印出的内容,我们无法阅读,其实,让我们自己来解析一封复杂的邮件是很不容易的,邮件里面格式.规范复杂得很.不过,我们所用的浏览器内置了解析各种数据类 ...

  3. mybatis mapper association collection

    1.Question Description: sometimes, POJO bean contains another bean or collection as property, it's s ...

  4. (旧)子数涵数·PS——换脸

    一.打开Photoshop,打开下载好的两张素材图(均在百度下载的). 二.选中人物脸的部分,不需要很精确(哪种抠图方式都行,我用的是矩形选框工具),再使用移动工具(快捷键为V,或者按着Ctrl),将 ...

  5. j2ee log4j集中式日志解决方案logpool v0.3

    V0.3相对于v0.2的更新如下:

  6. play framework学习笔记之 模板引擎

    模板语法 ${client.name} ${client?.name} 不能确定client是否存在的时候? #{extends /} #{doLayout /}#{get} #{set} 比如 #{ ...

  7. Sass学习之路(2)——Sass环境安装(windows版)

    因为本喵目前用的是window10的本子,所以这里就发windows版本的安装流程啦.(希望有朋友可以赞助我一个mac(┳_┳)): 第一步:安装ruby 因为Sass是基于ruby编写的,所以先去官 ...

  8. andriod RadioButton

    <?xml version="1.0" encoding="UTF-8"?> <LinearLayout android:orientatio ...

  9. Android-将RGB彩色图转换为灰度图

    package com.example.yanlei.wifi; import android.graphics.Bitmap; import android.graphics.BitmapFacto ...

  10. SharePoint 2010 文档管理之过期归档工具

    前言:使用过SharePoint的人都知道,SharePoint对于操作是便捷的,但是对于数据量承载却是不令人满意的,这样,就要求我们需要更加合理的使用,规范大家的使用规则和习惯,所以,定期清理不必要 ...