网站首页置灰-直取版(包含是否兼容ie的两种方案)

1. 不兼容ie方案

首页html添加样式

 <style>
 	html{
 		-webkit-filter: grayscale(100%); /* webkit */
 		-moz-filter: grayscale(100%); /*firefox*/
 		-ms-filter: grayscale(100%); /*ie9*/
 		-o-filter: grayscale(100%); /*opera*/
 		filter: grayscale(100%);
 		filter:progid:DXImageTransform.Microsoft.BasicImage(grayscale=1);
 		filter:gray; /*ie9- */
 	}
</style>

2. 兼容ie方案

首页html添加样式及逻辑:(所引用的js为grayscale.js)

 <style>
	html{
		-webkit-filter: grayscale(100%); /* webkit */
		-moz-filter: grayscale(100%); /*firefox*/
		-ms-filter: grayscale(100%); /*ie9*/
		-o-filter: grayscale(100%); /*opera*/
		filter: grayscale(100%);
		filter:progid:DXImageTransform.Microsoft.BasicImage(grayscale=1);
		filter:gray; /*ie9- */
	}
</style>
<script type="text/javascript" src="../../js/grayscale.js"></script>
<script type="text/javascript">
	// 判断浏览器版本
	window.onload = function () {
		var navStr = navigator.userAgent.toLowerCase();
		if(navStr.indexOf("msie 10.0")!==-1||navStr.indexOf("rv:11.0")!==-1){ // 判断是IE10或者IE11
			grayscale(document.getElementById('grayEle')); // 给html标签添加id
		}
	}
</script>

grayscale文件内容:

  /*
  * -- grayscale.js --
  * Copyright (C) James Padolsey (http://james.padolsey.com)
  *
  */
 
 var grayscale = (function(){
 
     var config = {
             colorProps: ['color','backgroundColor','borderBottomColor','borderTopColor','borderLeftColor','borderRightColor','backgroundImage'],
             externalImageHandler : {
                 /* Grayscaling externally hosted images does not work
                    - Use these functions to handle those images as you so desire */
                 /* Out of convenience these functions are also used for browsers
                    like Chrome that do not support CanvasContext.getImageData */
                 init : function(el, src) {
                     if (el.nodeName.toLowerCase() === 'img') {
                         // Is IMG element...
                     } else {
                         // Is background-image element:
                         // Default - remove background images
                         data(el).backgroundImageSRC = src;
                         el.style.backgroundImage = '';
                     }
                 },
                 reset : function(el) {
                     if (el.nodeName.toLowerCase() === 'img') {
                         // Is IMG element...
                     } else {
                         // Is background-image element:
                         el.style.backgroundImage = 'url(' + (data(el).backgroundImageSRC || '') + ')';
                     }
                 }
             }
         },
         log = function(){
             try { window.console.log.apply(console, arguments); }
             catch(e) {};
         },
         isExternal = function(url) {
             // Checks whether URL is external: 'CanvasContext.getImageData'
             // only works if the image is on the current domain.
             return (new RegExp('https?://(?!' + window.location.hostname + ')')).test(url);
         },
         data = (function(){
 
             var cache = [0],
                 expando = 'data' + (+new Date());
 
             return function(elem) {
                 var cacheIndex = elem[expando],
                     nextCacheIndex = cache.length;
                 if(!cacheIndex) {
                     cacheIndex = elem[expando] = nextCacheIndex;
                     cache[cacheIndex] = {};
                 }
                 return cache[cacheIndex];
             };
 
         })(),
         desatIMG = function(img, prepare, realEl) {
 
             // realEl is only set when img is temp (for BG images)
 
             var canvas = document.createElement('canvas'),
                 context = canvas.getContext('2d'),
                 height = img.naturalHeight || img.offsetHeight || img.height,
                 width = img.naturalWidth || img.offsetWidth || img.width,
                 imgData;
 
             canvas.height = height;
             canvas.width = width;
             context.drawImage(img, 0, 0);
             try {
                 imgData = context.getImageData(0, 0, width, height);
             } catch(e) {}
 
             if (prepare) {
                 desatIMG.preparing = true;
                 // Slowly recurse through pixels for prep,
                 // :: only occurs on grayscale.prepare()
                 var y = 0;
                 (function(){
 
                     if (!desatIMG.preparing) { return; }
 
                     if (y === height) {
                         // Finished!
                         context.putImageData(imgData, 0, 0, 0, 0, width, height);
                         realEl ? (data(realEl).BGdataURL = canvas.toDataURL())
                             : (data(img).dataURL = canvas.toDataURL())
                     }
 
                     for (var x = 0; x < width; x++) {
                         var i = (y * width + x) * 4;
                         // Apply Monoschrome level across all channels:
                         imgData.data[i] = imgData.data[i+1] = imgData.data[i+2] =
                             RGBtoGRAYSCALE(imgData.data[i], imgData.data[i+1], imgData.data[i+2]);
                     }
 
                     y++;
                     setTimeout(arguments.callee, 0);
 
                 })();
                 return;
             } else {
                 // If desatIMG was called without 'prepare' flag
                 // then cancel recursion and proceed with force! (below)
                 desatIMG.preparing = false;
             }
 
             for (var y = 0; y < height; y++) {
                 for (var x = 0; x < width; x++) {
                     var i = (y * width + x) * 4;
                     // Apply Monoschrome level across all channels:
                     imgData.data[i] = imgData.data[i+1] = imgData.data[i+2] =
                         RGBtoGRAYSCALE(imgData.data[i], imgData.data[i+1], imgData.data[i+2]);
                 }
             }
 
             context.putImageData(imgData, 0, 0, 0, 0, width, height);
             return canvas;
 
         },
         getStyle = function(el, prop) {
             var style = document.defaultView && document.defaultView.getComputedStyle ?
                 document.defaultView.getComputedStyle(el, null)[prop]
                 : el.currentStyle[prop];
             // If format is #FFFFFF: (convert to RGB)
             if (style && /^#[A-F0-9]/i.test(style)) {
                 var hex = style.match(/[A-F0-9]{2}/ig);
                 style = 'rgb(' + parseInt(hex[0], 16) + ','
                     + parseInt(hex[1], 16) + ','
                     + parseInt(hex[2], 16) + ')';
             }
             return style;
         },
         RGBtoGRAYSCALE = function(r,g,b) {
             // Returns single monochrome figure:
             return parseInt( (0.2125 * r) + (0.7154 * g) + (0.0721 * b), 10 );
         },
         getAllNodes = function(context) {
             var all = Array.prototype.slice.call(context.getElementsByTagName('*'));
             all.unshift(context);
             return all;
         };
 
     var init = function(context) {
 
         // Handle if a DOM collection is passed instead of a single el:
         if (context && context[0] && context.length && context[0].nodeName) {
             // Is a DOM collection:
             var allContexts = Array.prototype.slice.call(context),
                 cIndex = -1, cLen = allContexts.length;
             while (++cIndex<cLen) { init.call(this, allContexts[cIndex]); }
             return;
         }
 
         context = context || document.documentElement;
 
         if (!document.createElement('canvas').getContext) {
             context.style.filter = 'progid:DXImageTransform.Microsoft.BasicImage(grayscale=1)';
             context.style.zoom = 1;
             return;
         }
 
         var all = getAllNodes(context),
             i = -1, len = all.length;
 
         while (++i<len) {
             var cur = all[i];
 
             if (cur.nodeName.toLowerCase() === 'img') {
                 var src = cur.getAttribute('src');
                 if(!src) { continue; }
                 if (isExternal(src)) {
                     config.externalImageHandler.init(cur, src);
                 } else {
                     data(cur).realSRC = src;
                     try {
                         // Within try statement just encase there's no support....
                         cur.src = data(cur).dataURL || desatIMG(cur).toDataURL();
                     } catch(e) { config.externalImageHandler.init(cur, src); }
                 }
 
             } else {
                 for (var pIndex = 0, pLen = config.colorProps.length; pIndex < pLen; pIndex++) {
                     var prop = config.colorProps[pIndex],
                         style = getStyle(cur, prop);
                     if (!style) {continue;}
                     if (cur.style[prop]) {
                         data(cur)[prop] = style;
                     }
                     // RGB color:
                     if (style.substring(0,4) === 'rgb(') {
                         var monoRGB = RGBtoGRAYSCALE.apply(null, style.match(/\d+/g));
                         cur.style[prop] = style = 'rgb(' + monoRGB + ',' + monoRGB + ',' + monoRGB + ')';
                         continue;
                     }
                     // Background Image:
                     if (style.indexOf('url(') > -1) {
                         var urlPatt = /\(['"]?(.+?)['"]?\)/,
                             url = style.match(urlPatt)[1];
                         if (isExternal(url)) {
                             config.externalImageHandler.init(cur, url);
                             data(cur).externalBG = true;
                             continue;
                         }
                         // data(cur).BGdataURL refers to caches URL (from preparation)
                         try {
                             var imgSRC = data(cur).BGdataURL || (function(){
                                 var temp = document.createElement('img');
                                 temp.src = url;
                                 return desatIMG(temp).toDataURL();
                             })();
 
                             cur.style[prop] = style.replace(urlPatt, function(_, url){
                                 return '(' + imgSRC + ')';
                             });
                         } catch(e) { config.externalImageHandler.init(cur, url); }
                     }
                 }
             }
         }
 
     };
 
     init.reset = function(context) {
         // Handle if a DOM collection is passed instead of a single el:
         if (context && context[0] && context.length && context[0].nodeName) {
             // Is a DOM collection:
             var allContexts = Array.prototype.slice.call(context),
                 cIndex = -1, cLen = allContexts.length;
             while (++cIndex<cLen) { init.reset.call(this, allContexts[cIndex]); }
             return;
         }
         context = context || document.documentElement;
         if (!document.createElement('canvas').getContext) {
             context.style.filter = 'progid:DXImageTransform.Microsoft.BasicImage(grayscale=0)';
             return;
         }
         var all = getAllNodes(context),
             i = -1, len = all.length;
         while (++i<len) {
             var cur = all[i];
             if (cur.nodeName.toLowerCase() === 'img') {
                 var src = cur.getAttribute('src');
                 if (isExternal(src)) {
                     config.externalImageHandler.reset(cur, src);
                 }
                 cur.src = data(cur).realSRC || src;
             } else {
                 for (var pIndex = 0, pLen = config.colorProps.length; pIndex < pLen; pIndex++) {
                     if (data(cur).externalBG) {
                         config.externalImageHandler.reset(cur);
                     }
                     var prop = config.colorProps[pIndex];
                     cur.style[prop] = data(cur)[prop] || '';
                 }
             }
         }
     };
 
     init.prepare = function(context) {
 
         // Handle if a DOM collection is passed instead of a single el:
         if (context && context[0] && context.length && context[0].nodeName) {
             // Is a DOM collection:
             var allContexts = Array.prototype.slice.call(context),
                 cIndex = -1, cLen = allContexts.length;
             while (++cIndex<cLen) { init.prepare.call(null, allContexts[cIndex]); }
             return;
         }
 
         // Slowly recurses through all elements
         // so as not to lock up on the user.
 
         context = context || document.documentElement;
 
         if (!document.createElement('canvas').getContext) { return; }
 
         var all = getAllNodes(context),
             i = -1, len = all.length;
 
         while (++i<len) {
             var cur = all[i];
             if (data(cur).skip) { return; }
             if (cur.nodeName.toLowerCase() === 'img') {
                 if (cur.getAttribute('src') && !isExternal(cur.src)) {
                     desatIMG(cur, true);
                 }
 
             } else {
                 var style = getStyle(cur, 'backgroundImage');
                 if (style.indexOf('url(') > -1) {
                     var urlPatt = /\(['"]?(.+?)['"]?\)/,
                         url = style.match(urlPatt)[1];
                     if (!isExternal(url)) {
                         var temp = document.createElement('img');
                         temp.src = url;
                         desatIMG(temp, true, cur);
                     }
                 }
             }
         }
     };
 
     return init;
 
 })();

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值