前端面试常见问题(2018.10.18)

1. position的定位方式?查看

常见的有4种:

  • position:static(静态定位)

静态定位;是position的默认值,元素框正常生成,也就是没有定位时的正常显示。

  • position:relative(相对定位)

生成的位置相对于自身定位的,需要注意的是使用position:relative的元素并没有脱离文档流,且原来的位置占用的空间依旧存在,只是位置发生了变化。一般使用relative来改变位置比较少,主要是用来设置子级的absolute定位的参考对象。

  • position:absolute(绝对定位)

absolute定位是布局中最常用到的定位,其生成的位置是相对于带有position属性的父(父...)级来定位;如果父级都没有position属性,则相对于document来定位;使用absolute定位后,定位元素是脱离文档流的,这时候父级会检测不到定位元素的宽高。inline元素使用absolute定位之后,可以对其设置宽高;元素是不可以同时使用绝对定位和浮动的。

  • position:fixed(固定定位)

fixed定位是相对于浏览器窗口来定位的,所以也是脱离了文档流,与absolute一样,父级会检测不到定位元素的宽高。inline元素使用fixed定位之后,可以对其设置宽高;元素是不可以同时使用fixed定位和浮动的。

另外,还有4种不常见的:

  • position: inherit;  // 继承父元素的position属性
  • position: initial;  // 设置属性为默认值
  • position: unset;    // 不设置属性
  • position: sticky;   // 粘性定位

2. 描述下从输入URL到整个网页加载完毕及显示在屏幕上的整个流程 查看

(1)、输入url地址
(2)、浏览器查找域名的 IP 地址  
(3)、浏览器向 web 服务器发送一个 HTTP 请求
(4)、服务器的永久重定向响应
(5)、浏览器跟踪重定向地址
(6)、服务器处理请求
(7)、服务器返回一个 HTTP 响应 
(8)、浏览器显示 HTML
(9)、浏览器发送请求获取嵌入在 HTML 中的资源(如图片、音频、视频、CSS、JS等等)
3. 描述一下渐进增强和优雅降级之间的不同

  •  渐进增强(progressive enhancement):针对低版本浏览器进行构建页面,保证最基本的功能,然后再针对高级浏览器进行效果、交互等改进和追加功能达到更好的用户体验。 
  • 优雅降级(graceful degradation):一开始就构建完整的功能,然后再针对低版本浏览器进行兼容。

区别:优雅降级是从复杂的现状开始,并试图减少用户体验的供给,而渐进增强则是从一个非常基础的,能够起作用的版本开始,并不断扩充,以适应未来环境的需要。降级(功能衰减)意味着往回看;而渐进增强则意味着朝前看,同时保证其根基处于安全地带。  

优雅降级”观点
“优雅降级”观点认为应该针对那些最高级、最完善的浏览器来设计网站。而将那些被认为“过时”或有功能缺失的浏览器下的测试工作安排在开发周期的最后阶段,并把测试对象限定为主流浏览器(如 IE、Mozilla 等)的前一个版本。
在这种设计范例下,旧版的浏览器被认为仅能提供“简陋却无妨 (poor, but passable)” 的浏览体验。你可以做一些小的调整来适应某个特定的浏览器。但由于它们并非我们所关注的焦点,因此除了修复较大的错误之外,其它的差异将被直接忽略。

“渐进增强”观点
“渐进增强”观点则认为应关注于内容本身。

内容是我们建立网站的诱因。有的网站展示它,有的则收集它,有的寻求,有的操作,还有的网站甚至会包含以上的种种,但相同点是它们全都涉及到内容。这使得“渐进增强”成为一种更为合理的设计范例。这也是它立即被 Yahoo! 所采纳并用以构建其“分级式浏览器支持 (Graded Browser Support)”策略的原因所在

猜你喜欢

转载自blog.csdn.net/qq_41261490/article/details/83144772