如何基于filter实现网站整体变灰功能

时间:2021-05-18

前言

政府网站会遇到公祭日的时候,网站整体颜色变灰的情况。今天正好调了一下。在此把解决方案分享给大家。方案简单实用,笔者已在生产环境使用过。通过整体的html使用filter来进行过滤。如下,只要引入即可。

解决方案

html { filter: url("data:image/svg+xml;utf8,#grayscale"); -webkit-filter: grayscale(100%); filter: grayscale(100%); filter: gray; filter:progid:DXImageTransform.Microsoft.BasicImage(grayscale=1);}

IE11 和 IE10的解决方案

经过测试发现,以上代码的方式对于谷歌,火狐,IE8,9都很好使。对于IE11和IE10效果不奏效。于是我们采取另一种方式,通过引用grayscale.js来使用。由于不能上传文件,在此将grayscale.js的代码写下来。

/* * -- grayscale.js -- * Copyright (C) James Padolsey (http://james.padolsey.com) * Download by //putedStyle(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;})();使用方式如下,中心思想就是当我们是ie10和ie11浏览器的时候,调用graystyle的js函数。<script type="text/javascript"> var navStr = navigator.userAgent.toLowerCase(); if(navStr.indexOf("msie 10.0")!==-1||navStr.indexOf("rv:11.0")!==-1){ // 判断是IE10或者IE11 $(function () { grayscale($('body')); }) }</script>

这里建议直接捕捉body,如果想针对某一个,换其中的捕捉元素就可以。

总结

至此,网站变灰的方案就完美了。完美兼容各种浏览器,笔者已经在生产环境使用过了,大家放心使用。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。

声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。

相关文章