一、题目
用JS代码求出页面上一个元素的最终的background-color,不考虑IE浏览器,不考虑元素float情况。
二、题目解析
1.考察底层JavaScript基础
前端开发,日常最常接触的就是页面样式的编写。而摆脱jQuery等工具库,用原生js获取样式,是每个前端程序猿进阶阶段必须掌握的技能。
2.考察面试者的思维缜密程度和开发经验
如果认为单单求元素计算后的样式,就有点too young了。页面的样式的复杂,永远是最虐心的。就算前端有多牛逼,一听到兼容IE6,论谁都会心塞"color: #800000">1. 内联样式
内联样式可以通过元素的style属性获取,如果style属性有background-color值,则可以直接获取出来 (暂不考虑!important) 。
2. 外联的层叠样式
DOM2样式规范在document.defaultView中包含了一个getComputedStyle()方法。该方法返回一个只读的CSSStyleDeclaration对象,其中包含特定元素的所有计算样式。
四、解题
4.1 将所有工具方法封装在WDS(wall dom script)命名空间中
(function(WDS, undefined){ // 封装代码... })(window.WDS || (window.WDS = {}));
代码封装在命名空间里,不会造成无意间的代码污染。
4.2 工具方法camelize
// 字符串转换为驼峰写法 function camelize(str) { return str.replace(/-(\w)/g, function (strMatch, p1){ return p1.toUpperCase(); }); }
该方法是为了方便后续getStyle()方法的编写,而独立出来的。
作用是将连字符类的css属性值,转换成驼峰写法。
例如:将background-color转换为backgroundColor
4.3 获取特定元素的计算样式
// 获取元素计算后的样式 function getStyle(elem, property){ if(!elem || !property){ return false; } var value = elem.style[camelize(property)], // 先获取是否有内联样式 css; // 获取的所有计算样式 // 无内联样式,则获取层叠样式表计算后的样式 if(!value){ if(document.defaultView && document.defaultView.getComputedStyle){ css = document.defaultView.getComputedStyle(elem, null); value = css "color: #800000">4.4 排除特殊情况// 检测获取的背景色是否有效 function checkBgValue(elem){ var value = getStyle(elem, 'background-color'), hasColor = value "transparent" || value == "rgba(0, 0, 0, 0)"){ // 未设置background-color,或者设置为跟随父节点 hasColor = false; }else if(getStyle(elem, 'opacity') == "0"){ // dom节点透明度为全透明 hasColor = false; }else if(getStyle(elem, 'visibility') == "hidden"){ // dom节点不可见 hasColor = false; }else if(getStyle(elem, 'display') == "none"){ // dom节点不可见 hasColor = false; } return hasColor; }4.5 获取div在页面最终显示的颜色
// 获取div最终显示的颜色 function getRealBg(elem){ if(checkBgValue(elem)){ return getStyle(elem, 'background-color'); }else if(elem != document.documentElement){ return getRealBg(elem.parentNode); } return ''; }获取样式值采用递归方式处理。
如果能顺利获取到元素样式,且不触发4.4 排除特殊情况中的一种,则直接返回结果。
触发了特殊情况,则需要查找父节点以及更上层的节点的样式,来获取肉眼能看到,显示在页面上的background-color值。
在向上回溯的过程中,如果已经回溯到html根节点,则可以停止回溯。所以加了判断else if(elem != document.documentElement)
五、遗漏的大boss
5.1 大boss !important
如果乱用 !important,对大型项目的维护和开发,绝对是一场噩梦。因为优先级规则的计算,!important永远处在食物链的最顶层。
当前题目不考虑这种情况,也是我的偷懒"color: #800000">5.2 大boss 父节点及根节点设置了不可见css属性
只要设置该css语句:html {display:none;},页面所有元素立刻消失不见。而任意特定元素的上级节点,只要设置了 opacity,display,visibility,判断逻辑瞬间变得复杂起来。所以,这个浑水我也不趟 O(∩_∩)O哈哈~
六、改进的点
其实特殊情况排除的判断,我偷懒没做到最好——rgb颜色值和特定颜色值(比如red)没有进行统一的转换,只是加了生硬的判断if(value == "transparent" || value == "rgba(0, 0, 0, 0)")。
有兴趣的可以搜索下颜色值转换的js方法,这里我就不写了。
七、源码和demo
源码地址:https://github.com/wall-wxk/blogDemo/blob/master/2017/02/05/getStyle.html
demo:https://wall-wxk.github.io/blogDemo/2017/02/05/getStyle.html
以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,同时也希望多多支持!
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
P70系列延期,华为新旗舰将在下月发布
3月20日消息,近期博主@数码闲聊站 透露,原定三月份发布的华为新旗舰P70系列延期发布,预计4月份上市。
而博主@定焦数码 爆料,华为的P70系列在定位上已经超过了Mate60,成为了重要的旗舰系列之一。它肩负着重返影像领域顶尖的使命。那么这次P70会带来哪些令人惊艳的创新呢?
根据目前爆料的消息来看,华为P70系列将推出三个版本,其中P70和P70 Pro采用了三角形的摄像头模组设计,而P70 Art则采用了与上一代P60 Art相似的不规则形状设计。这样的外观是否好看见仁见智,但辨识度绝对拉满。
更新日志
- 凤飞飞《我们的主题曲》飞跃制作[正版原抓WAV+CUE]
- 刘嘉亮《亮情歌2》[WAV+CUE][1G]
- 红馆40·谭咏麟《歌者恋歌浓情30年演唱会》3CD[低速原抓WAV+CUE][1.8G]
- 刘纬武《睡眠宝宝竖琴童谣 吉卜力工作室 白噪音安抚》[320K/MP3][193.25MB]
- 【轻音乐】曼托凡尼乐团《精选辑》2CD.1998[FLAC+CUE整轨]
- 邝美云《心中有爱》1989年香港DMIJP版1MTO东芝首版[WAV+CUE]
- 群星《情叹-发烧女声DSD》天籁女声发烧碟[WAV+CUE]
- 刘纬武《睡眠宝宝竖琴童谣 吉卜力工作室 白噪音安抚》[FLAC/分轨][748.03MB]
- 理想混蛋《Origin Sessions》[320K/MP3][37.47MB]
- 公馆青少年《我其实一点都不酷》[320K/MP3][78.78MB]
- 群星《情叹-发烧男声DSD》最值得珍藏的完美男声[WAV+CUE]
- 群星《国韵飘香·贵妃醉酒HQCD黑胶王》2CD[WAV]
- 卫兰《DAUGHTER》【低速原抓WAV+CUE】
- 公馆青少年《我其实一点都不酷》[FLAC/分轨][398.22MB]
- ZWEI《迟暮的花 (Explicit)》[320K/MP3][57.16MB]