资讯专栏INFORMATION COLUMN

献给前端求职路上的你们(上)

jackzou / 3096人阅读

摘要:事件如何使用事件,以及和标准事件模型之间存在的差别以及常用的事件委托。模拟老式浏览器的行为以防止站点无法工作。首先,巧妙的使用这一标记,将游览器从所有情况中分离出来。搜索引擎的爬虫依赖于标记来确定上下文和各个关键字的权重,利于。

(在放大镜中寻找你)

前言

我是一名前端开发,从2016年6月毕业到如今步入工作,期间也面试了一些公司,参考过一些面试文档,学习了一些面试宝典,掌握了一些面试、笔试技巧和经验,所以就总结了一些优质的前端面试题以及面试要点,初学者阅后也要用心钻研其中的原理,重要知识需要系统学习,透彻学习,才能形成自己的知识链,以不变应万变,万不可投机取巧,只求面试过关哦!

面试注意点

面试题目: 根据你的等级和职位变化,入门级到专家级:范围↑、深度↑、方向↑、新技术↑。

题目类型: 技术视野、项目细节、理论知识题,算法题,开放性题,案例题。

进行追问: 可以确保问到你开始不懂或面试官开始不懂为止,这样可以大大延展题目的区分度和深度,知道你的实际能力。因为这种关联知识是长时间的学习,绝对不是临时抱佛脚得来的。

言语态度:回答问题再棒,面试官(可能是你的直接领导面试),会考虑我要不要这个人做我的同事?做我的员工?所以态度很重要。(感觉更像是相亲)

硬知识才能:资深的工程师能把absolute和relative弄混,这样的人不要也罢,因为团队需要的你这个人具有可以依靠的才能(靠谱)。

前端开发面试知识点大纲

1、HTML&CSS

html:超级文本标记语言(HyperText Markup Language)

css:层叠样式表(Cascading Style Sheets)对Web标准的理解、浏览器内核差异、兼容性、hack、CSS基本功:布局、盒子模型、浮动和定位、选择器优先级及使用、HTML5、CSS3、移动端适应

2、JavaScript

ECMAScript标准规范,描述这门语言的实现细节和标准。

基础部分
数据类型、运算符、结构语句、面向对象、函数、正则表达式。

应用部分
window对象、document对象、继承、闭包、插件、作用域、跨域、原型链、模块化、自定义事件、内存泄漏、事件机制、异步装载回调、模板引擎、Nodejs、JSON、ajax等

3、jQuery
对象的结构、jQuery的方法挂在哪里、插件制作、jQuery的常用方法、选择器、jQuery的事件用法

4、其他

HTTP、安全、正则、优化、重构、响应式、移动端、团队协作、后台相关、编辑器和自动化工具、新技术、前端自动化、可维护、SEO、UED、架构、职业生涯等

必备知识点

作为一名前端工程师,无论工作年头长短都应该必须掌握的知识点

DOM结构 —— 两个节点之间可能存在哪些关系以及如何在节点之间任意移动。

DOM操作 ——如何添加、移除、移动、复制、创建和查找节点等。

事件 —— 如何使用事件,以及IE和标准DOM事件模型之间存在的差别,以及常用的事件委托。

XMLHttpRequest —— 这是什么、怎样完整地执行一次GET请求、怎样检测错误。

严格模式与混杂模式 —— 如何触发这两种模式,区分它们有何意义。

盒模型 —— 外边距、内边距和边框之间的关系,及IE8以下版本的浏览器中的盒模型

块级元素与行内元素 —— 怎么用CSS控制它们、以及如何合理的使用它们

浮动元素——怎么使用它们、它们有什么问题以及怎么解决这些问题。

HTML与XHTML——二者有什么区别,你觉得应该使用哪一个并说出理由。

JSON —— 作用、用途、设计结构。

备注
根据自己需要选择性阅读,面试题是对理论知识的总结,让自己学会应该如何表达。资料答案不够正确和全面,欢迎补充答案、题目;最好是现在网上没有的。格式不断修改更新中。

HTML

WEB标准以及W3C标准是什么?

标签闭合、标签小写、不乱嵌套、使用外链css和js、结构行为表现的分离。

xhtml和html有什么区别?

一个是功能上的差别
主要是XHTML可兼容各大浏览器、手机以及PDA,并且浏览器也能快速正确地编译网页。

另外是书写习惯的差别。
XHTML 元素必须被正确地嵌套,闭合,区分大小写,文档必须拥有根元素

Doctype作用? 严格模式与混杂模式如何区分?它们有何意义?

声明位于文档中的最前面,处于 标签之前。告知浏览器的解析器, 用什么文档类型 规范来解析这个文档

严格模式的排版和 JS 运作模式是 以该浏览器支持的最高标准运行。

在混杂模式中,页面以宽松的向后兼容的方式显示。模拟老式浏览器的行为以防止站点无法工作。 DOCTYPE不存在或格式不正确会导致文档以混杂模式呈现。

行内元素有哪些?块级元素有哪些? 空(void)元素有那些?行内元素和块级元素有什么区别?

CSS规范规定,每个元素都有display属性,确定该元素的类型,每个元素都有默认的display值, 比如div默认display属性值为“block”,成为“块级”元素; span默认display属性值为“inline”,是“行内”元素。

行内元素有:a b span img input select strong(强调的语气)

块级元素有:div ul ol li dl dt dd h1 h2 h3 h4…p

知名的空元素:`


鲜为人知的是:

行内元素不可以设置宽高,不独占一行;

块级元素可以设置宽高,独占一行。

link 和@import 的区别是?

link属于XHTML标签,而@import是CSS提供的;

页面被加载的时,link会同时被加载,而@import引用的CSS会等到页面被加载完再加载;

import只在IE5以上才能识别,而link是XHTML标签,无兼容问题;

link方式的样式的权重 高于@import的权重。

浏览器的内核分别是什么?

IE浏览器的内核Trident、Mozilla的Gecko、Chrome的Blink(WebKit的分支)、Opera内核原为Presto,现为Blink。

常见兼容性问题?

png24位的图片在iE6浏览器上出现背景,解决方案是做成PNG8。

浏览器默认的margin和padding不同。解决方案是加一个全局的*{margin:0;padding:0;}来统一,,但是全局效率很低,一般是如下这样解决:

body,ul,li,ol,dl,dt,dd,form,input,h1,h2,h3,h4,h5,h6,p{
    margin:0;
    padding:0;
    }

IE6双边距bug:块属性标签float后,又有横行的margin情况下,在ie6显示margin比设置的大。
浮动ie产生的双倍距离#box{ float:left; width:10px; margin:0 0 0 100px;}这种情况之下IE会产生20px的距离,解决方案是在float的标签样式控制中加入 ——_display:inline;将其转化为行内属性。(_这个符号只有ie6会识别)渐进识别的方式,从总体中逐渐排除局部。首先,巧妙的使用“9”这一标记,将IE游览器从所有情况中分离出来。接着,再次使用“+”将IE8和IE7、IE6分离开来,这样IE8已经独立识别。

css中存在的兼容问题

    .bb{
      background-color:#f1ee18;/*所有识别*/
      .background-color:#00deff9; /*IE6、7、8识别*/
      +background-color:#a200ff;/*IE6、7识别*/
      _background-color:#1e0bd1;/*IE6识别*/ 
    }

IE下,可以使用获取常规属性的方法来获取自定义属性,也可以使用getAttribute()获取自定义属性;Firefox下,只能使用getAttribute()获取自定义属性.解决方法:统一通过getAttribute()获取自定义属性.

IE下,even对象有x,y属性,但是没有pageX,pageY属性;Firefox下,event对象有pageX,pageY属性,但是没有x,y属性.

解决方法:(条件注释)缺点是在IE浏览器下可能会增加额外的HTTP请求数。

Chrome 中文界面下默认会将小于 12px 的文本强制按照 12px 显示,可通过加入 CSS 属性-webkit-text-size-adjust: none; 解决.超链接访问过后hover样式就不出现了 被点击访问过的超链接样式不在具有hover和active了解决方法是改变CSS属性的排列顺序:L-V-H-A : a:link {} a:visited {} a:hover {} a:active {}

html5有哪些新特性、移除了那些元素?如何处理HTML5新标签的浏览器兼容问题?如何区分 HTML 和 HTML5?

HTML5 现在已经不是 SGML 的子集,主要是关于图像,位置,存储,多任务、画布、强后台相关技术等功能的增加。他的新的定义为:一套新的javascriptAPI和若干小的对html结构的改动

绘画 canvas
用于媒介回放的 video 和 audio 元素。本地离线存储 localStorage 长期存储数据,浏览器关闭后数据不丢失;sessionStorage 的数据在浏览器关闭后自动删除。语意化更好的内容元素,比如 article、footer、header、nav、section。表单控件,calendar、date、time、email、url、search。新的技术webworker, websockt, Geolocation

移除的元素
纯表现的元素:basefont,big,center,font, s,strike,tt,u;对可用性产生负面影响的元素:frame,frameset,noframes;支持HTML5新标签:

IE8/IE7/IE6支持通过document.createElement方法产生的标签,
可以利用这一特性让这些浏览器支持HTML5新标签,浏览器支持新标签后,还需要添加标签默认的样式:

当然最好的方式是直接使用成熟的框架、使用最多的是html5shim框架

语义化的理解?

用正确的标签做正确的事情!

html语义化就是让页面的内容结构化,便于对浏览器、搜索引擎解析;

在没有样式CCS情况下也以一种文档格式显示,并且是容易阅读的。

搜索引擎的爬虫依赖于标记来确定上下文和各个关键字的权重,利于 SEO。

使阅读源代码的人对网站更容易将网站分块,便于阅读维护理解。

HTML5的离线储存?

localStorage 长期存储数据,浏览器关闭后数据不丢失;

sessionStorage 数据在浏览器关闭后自动删除。

(写)描述一段语义的html代码
(HTML5中新增加的很多标签(如:

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/116603.html

相关文章

  • 献给前端求职你们(下)

    摘要:一般情况下是全局对象。是可以被侦测到的行为。顾名思义,这种模式使得在更严格的条件下运行。安全问题暴露了与服务器交互的细节。破坏了程序的异常机制。避免使用表达式又称动态属性。用于表示请求成功。 注明:上一篇献给前端求职路上的你们(上),主要侧重说的是前端面试中的html和css这两块常见问题,这是基础,其实在真正面试中,面试官往往采用的是由难到易的套路,那js和jQuery就是重中之重了...

    马永翠 评论0 收藏0
  • 献给前端求职你们(下)

    摘要:一般情况下是全局对象。是可以被侦测到的行为。顾名思义,这种模式使得在更严格的条件下运行。安全问题暴露了与服务器交互的细节。破坏了程序的异常机制。避免使用表达式又称动态属性。用于表示请求成功。 注明:上一篇献给前端求职路上的你们(上),主要侧重说的是前端面试中的html和css这两块常见问题,这是基础,其实在真正面试中,面试官往往采用的是由难到易的套路,那js和jQuery就是重中之重了...

    libxd 评论0 收藏0
  • 献给前端求职你们(下)

    摘要:一般情况下是全局对象。是可以被侦测到的行为。顾名思义,这种模式使得在更严格的条件下运行。安全问题暴露了与服务器交互的细节。破坏了程序的异常机制。避免使用表达式又称动态属性。用于表示请求成功。 注明:上一篇献给前端求职路上的你们(上),主要侧重说的是前端面试中的html和css这两块常见问题,这是基础,其实在真正面试中,面试官往往采用的是由难到易的套路,那js和jQuery就是重中之重了...

    Wuv1Up 评论0 收藏0
  • 献给前端求职你们

    摘要:事件如何使用事件,以及和标准事件模型之间存在的差别以及常用的事件委托。模拟老式浏览器的行为以防止站点无法工作。首先,巧妙的使用这一标记,将游览器从所有情况中分离出来。搜索引擎的爬虫依赖于标记来确定上下文和各个关键字的权重,利于。 showImg(https://segmentfault.com/img/remote/1460000008630900); (在放大镜中寻找你) 前言 我是...

    animabear 评论0 收藏0
  • 献给前端求职你们

    摘要:事件如何使用事件,以及和标准事件模型之间存在的差别以及常用的事件委托。模拟老式浏览器的行为以防止站点无法工作。首先,巧妙的使用这一标记,将游览器从所有情况中分离出来。搜索引擎的爬虫依赖于标记来确定上下文和各个关键字的权重,利于。 showImg(https://segmentfault.com/img/remote/1460000008630900); (在放大镜中寻找你) 前言 我是...

    hiyang 评论0 收藏0

发表评论

0条评论

jackzou

|高级讲师

TA的文章

阅读更多
最新活动
阅读需要支付1元查看
<