在网上百度到的解决办法,感觉不错,和大家分享一下。

在CSS样式里加一句代码“body{behavior:url("文件夹/csshover.htc");}”即可。

csshover.htc文件可以在网上搜索下载,也可以自己建立,文件具体内容如下:

<attach event="ondocumentready" handler="parseStylesheets" />

<script language="JScript">

var currentSheet, doc = window.document, activators = {

onhover:{on:'onmouseover', off:'onmouseout'},

onactive:{on:'onmousedown', off:'onmouseup'}

}

function parseStylesheets() {

//window.alert("hi");

var sheets = doc.styleSheets, l = sheets.length;

for(var i=0; i<l; i++) 

   parseStylesheet(sheets[i]);

}

function parseStylesheet(sheet) {

   if(sheet.imports) {

    try {

     var imports = sheet.imports, l = imports.length;

     for(var i=0; i<l; i++) parseStylesheet(sheet.imports[i]);

    } catch(securityException){}

   }

try {

    var rules = (currentSheet = sheet).rules, l = rules.length;

    for(var j=0; j<l; j++) parseCSSRule(rules[j]);

   } catch(securityException){}

}

function parseCSSRule(rule) {

   var select = rule.selectorText, style = rule.style.cssText;

   if(!(/(^|\s)(([^a]([^ ]+)?)|(a([^#.][^ ]+)+)):(hover|active)/i).test(select) || !style) return;

  

   var pseudo = select.replace(/[^:]+:([a-z-]+).*/i, 'on$1');

   var newSelect = select.replace(/(\.([a-z0-9_-]+):[a-z]+)|(:[a-z]+)/gi, '.$2' + pseudo);

   var className = (/\.([a-z0-9_-]*on(hover|active))/i).exec(newSelect)[1];

   var affected = select.replace(/:hover.*$/, '');

   var elements = getElementsBySelect(affected);

currentSheet.addRule(newSelect, style);

   for(var i=0; i<elements.length; i++)

    new HoverElement(elements[i], className, activators[pseudo]);

}

function HoverElement(node, className, events) {

if(!node.hovers) node.hovers = {};

if(node.hovers[className]) return;

node.hovers[className] = true;

node.attachEvent(events.on,

   function() { node.className += ' ' + className; });

node.attachEvent(events.off,

   function() { node.className = 

    node.className.replace(new RegExp('\\s+'+className, 'g'),''); });

}

function getElementsBySelect(rule) {

var parts, nodes = [doc];

parts = rule.split(' ');

for(var i=0; i<parts.length; i++) {

   nodes = getSelectedNodes(parts[i], nodes);

} return nodes;

}

function getSelectedNodes(select, elements) {

   var result, node, nodes = [];

   var classname = (/\.([a-z0-9_-]+)/i).exec(select);

   var identify = (/\#([a-z0-9_-]+)/i).exec(select);

   var tagName = select.replace(/(\.|\#|\:)[a-z0-9_-]+/i, '');

   for(var i=0; i<elements.length; i++) {

    result = tagName? elements[i].all.tags(tagName):elements[i].all; 

    for(var j=0; j<result.length; j++) {

     node = result[j];

     if((identify && node.id != identify[1]) || (classname && !(new RegExp('\\b' +

      classname[1] + '\\b').exec(node.className)))) continue;

     nodes[nodes.length] = node;

    }

   } return nodes;

}

</script>

[小知识点]IE6下不支持:hover的解决方法的更多相关文章

  1. bootstrap支持ie8 让IE6 IE7 IE8 IE9 IE10 IE11支持Bootstrap的解决方法

    做一个在线系统,PC端也要做,但要兼容千恶的IE8[IE6 是万恶,打死我都不会管IE6],IE8 是我底线了md, 在IE8下 bottstrap 错乱,变形,不支持一些属性的问题,下面看了一篇 某 ...

  2. 让IE6 IE7 IE8 IE9 IE10 IE11支持Bootstrap的解决方法--(转)

    如有雷同,不胜荣幸,若转载,请注明 让IE6 IE7 IE8 IE9 IE10 IE11支持Bootstrap的解决方法 最近做一个Web网站,之前一直觉得bootstrap非常好,这次使用了boot ...

  3. 转载------让IE6 IE7 IE8 IE9 IE10 IE11支持Bootstrap的解决方法

    本文是转载及收藏 让IE6 IE7 IE8 IE9 IE10 IE11支持Bootstrap的解决方法 最近做一个Web网站,之前一直觉得bootstrap非常好,这次使用了bootstrap3,在c ...

  4. win7 创建vhd提示“找不到指定文件的虚拟磁盘支持提供程序”解决方法

    本文参照:https://itbbs.pconline.com.cn/diy/16509116_2.html 14楼中"坚持不放弃"用户的答案得到解决 问题复现: 1.window ...

  5. Myeclipse下JSP打开报空指针异常解决方法。

    Myeclipse下JSP打开报空指针异常解决方法 一.运行JSP文件就出错 静态的JSP页面访问时候正常,只要是牵涉到数据库的页面就出错,出错见下图. 出现这种情况让我调试了一天,各种断点,各种改代 ...

  6. Windows下mysql忘记密码的解决方法

    Windows下mysql忘记密码的解决方法 mysql5.0 http://www.jb51.net/article/21984.htm方法一: 1.在DOS窗口下输入 net stop mysql ...

  7. mac下MySQL出现乱码的解决方法

    之前写过一篇Linux下MySQL出现乱码的解决方法,本文说下mac下的处理,其实处理方式是一样的,我电脑的mysql版本是5.7.26-log 网上很多帖子都说去/usr/local/mysql/s ...

  8. 关于img标签浏览器自带的边框,清除边框的解决方式(即img[src=""] img无路径情况下,灰色边框去除解决方法)

    详解img[src=""] img无路径情况下,灰色边框去除解决方法 1.Js解决办法 <html> <head> <meta charset=&qu ...

  9. 解决IE6下不支持 png24的透明图片问题

    常用的两种解决方案: 第一:使用IE滤镜解决 关键代码: css代码  _background:none;_filter:progid:DXImageTransform.Microsoft.Alpha ...

随机推荐

  1. R与数据分析旧笔记(十七) 主成分分析

    主成分分析 主成分分析 Pearson于1901年提出的,再由Hotelling(1933)加以发展的一种多变量统计方法 通过析取主成分显出最大的个别差异,也用来削减回归分析和聚类分析中变量的数目 可 ...

  2. 你需要了解的JS框架

    excanvas.js/Chart.js/cubism.js/d3.js/dc.js/dx.chartjs.js/echarts.js/flot.js       用途:构建数据统计图表,兼容多浏览器 ...

  3. 转: javascript模块加载框架seajs详解

    javascript模块加载框架seajs详解 SeaJS是一个遵循commonJS规范的javascript模块加载框架,可以实现javascript的模块化开发和模块化加载(模块可按需加载或全部加 ...

  4. Windows Latex 中日文字体设置例

    中文字体例: \documentclass[CJK]{article} \usepackage{CJKutf8} \newcommand{\songti}{\CJKfamily{song}} % 宋体 ...

  5. poj 1684 Lazy Math Instructor(字符串)

    题目链接:http://poj.org/problem?id=1686 思路分析:该问题为表达式求值问题,对于字母使用浮点数替换即可,因为输入中的数字只能是单个digit. 代码如下: #includ ...

  6. HDU1069:Monkey and Banana(DP+贪心)

    Problem Description A group of researchers are designing an experiment to test the IQ of a monkey. T ...

  7. android技术牛人的博客[转]

    Android+JNI调用–文件操作 开发环境:Windows xp sp3 +MyEclipse 8.6+android2.3.3+jdk1.6+android-ndk-r6b JNI概述:     ...

  8. C++学习笔记29,引用变量(1)

    引用变量在创建的时候就必须初始化.无法创建一个未被初始化的引用. #include <iostream> using namespace std; int main() { int x=1 ...

  9. POJ 3169 Layout (图论-差分约束)

    Layout Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 6574   Accepted: 3177 Descriptio ...

  10. Linux下PHP与普通C程序通信

    Linux下的普通C程序之前可以使用FIFO(有名管道来进行进程间通信,因为这个管道以一个文件的形式存在于文件系统上,因此只要能读写这个文件就可以实现进程间通信. 首先使用mkfifo命令有文件系统上 ...