前端面试题问题(前端面试题)

admin

2023-11-08 16:43:49

举报

小张

精选回答 本回答由提问者推荐举报

2023-11-08 16:43:49

微信号:13636477376
杭州高端ktv招聘 1500/1800/2000
复制微信号

  本文目录

  

  1. 你遇到的前端面试题都有什么
  2. 面试Web前端需要注意什么会面试哪些问题
  3. web前端面试经常问到的面试题有哪些

你遇到的前端面试题都有什么

  大家好,我是王我。

  随着春节的结束,各个行业也普遍开始了上班的节奏,不过本人17号才上班。为什么?因为长得帅的都上班比较晚。当然,每到新年结束,又迎来了一批招聘者与面试者,我来说说作为一年工作经验应该知道的面试题。

   HTML篇

   1.doctype是什么?有哪些类型?

   2.input有哪些新类型?简要说明其8用法。

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

   4.bootstrap响应式的原理是什么?

   5.多移动终端页面适配是如何实现的?

   CSS篇

   1.如何实现两列布局,左边自适应,右边固定宽度?

   2.用CSS画一个三角形

   3.CSS实现字体大写

   4.display有哪些常用的属性值?分别是什么意思?

   5.position为absolute,relative,fixed的定点位置

   6.用三种方法清除浮动

   7.请介绍一下margin塌陷问题

   js篇

   1.什么是事件冒泡和捕获?如何阻止事件冒泡?(分别用原生和jquery实现)

   2.js创建对象,至少使用三种方法

   3.简述一下事件穿透以及解决办法

   4.用三种方式判断变量类型是否是数组

   5.如何实现对象的拷贝?

   6.什么是闭包?闭包的优缺点。

   7.简述一下ajax请求的过程。

   8.简述一下new一个人构造函数的人过程。

   9.为什么会有跨域?是怎么解决跨域问题的?简述一下原理。

   10.js原始数据类型有哪些?

   11.学一个函数,判断一个变量是否是字符串

   12.typeof有哪些结果?

   13.剪头函数和普通函数有什么区别?

   14.请用三种方法实现数组去重

   15.href和src有什么区别?

   jquery篇

   1.attr()和prop()有什么区别?

   2.on和bind有什么区别?js动态添加的dom元素是通过on还是bind?

   3.touch和click有什么区别?

   4.window.onload和jquery的ready有什么区别?

   vue篇

   1.简述一下vue的生命周期及其特点

   2.vue双向绑定的原理是什么?

   3.vue的特点有哪些?和jquery有什么区别?

   4.父子组件之间传递数据的方法

   5.子组件如何共享数据?

   6.一般有什么工具进行数据交互?

   7.webpack的原理是什么?

   8.简述一下$nextTick的用法

  浏览器篇

   1.cookie、sessionStorage、localStorage的区别是什么?

   2.有用过浏览器缓存吗?简述一下基本的缓存机制

  网络篇

   1.http和https之间的区别

   2.从服务器的安全考虑,是使用get请求还是post请求?

   3.URL请求的过程有哪些?

  项目经验篇

   1.项目中遇到的最大挑战以及解决办法

   2.常见的网页优化有哪些?

  作为一个面试一年以内工作经验的前端程序员来说,以上的问题能够倒答如流月薪6k应该不成问题啦。这些面试题也是我在很多面试中感觉经常被问到的题目。

  希望大家年后找工作能够顺顺利利,千万不要跟我一样哦,只有帅气就一无所有了。

  大家好,我是王我,中国最帅的前端程序员。

  前几次都是各种培训公司,各种忽悠就不提了,说说后面4次面试的经历。

  第一次是面一个小公司,不过他们好像没有厉害的前端,来面我的是个后端,一来没有问我关于js的知识,直接问我以前做过什么,有没有经验,我本人不会吹牛,简历也没怎么包装,就是自己把自学的知识和做的几个小demo弄在上面,也用github挂在页面上了,不过他根本不点开看,也不问,问我会不会vue,我当时对框架还不了解,他就说他们需要能直接上手开始写的,所以我第一个就直接挂了。

  第二次面试是一个国企,这个问了很多问题,都很基础,js数据类型,数组操作,事件,大概就是高程的前面几章看看就差不多都能答到,然后因为他们主要用jq,所以问了很多jq的操作,关于节点的,动画的,我看锋利的jq大概看了3遍,也练过多次,所以我答的很熟。然后问了些布局方面的,bootstrap我了解过,又看过css3,所以这方面也没啥问题,最后在现场做了个题目,主要就是布局然后通过ajax呈现数据。后面听介绍我面试的说面试官比较满意,说我jq很熟,一面就过了。可惜后面电话面试不知怎么回事可能表现的不够自信,虽然没问技术,但是我没啥自信,把没项目经验什么的也不知怎么就一五一十交代了,估计因为这个挂掉了。

  第三次没问问题,直接就是一套题开做,我在那做了一个多小时。题目就是按照要求一步一步做一个页面出来,我也搞忘了我当时卡在哪个地方了,坐在那得时候就是做不出来,没有设计图,要根据他的描述自己找个设计图然后做,我第一次遇到这个有点懵,虽然当时没做出来,不过回来我自己花了几个小时把它做了。所以这个也是凉了。

  第四个问的比较多,数据类型,数组操作,跨域,ajax,闭包,原型链,继承,深拷贝,浅拷贝,模块amd cmd,基本都是问的js。然后问了html5的新特性 css3的新特性,遇到过什么浏览器的兼容性问题,怎么解决的,以后想往什么方面发展。这个时候我已经会点vue了,照着做了个小demo,不过后来知道公司用的angularjs,面试官也没看我做的,问也没问。。以前听网上说要带上自己的项目去面试感觉没起多大效果。

  最后总结下如果面的比较初级的岗位,应该主要问js,原型链,继承,闭包,深浅拷贝,ajax,跨域,然后js的基础知识,对了还有apply和call也问了,html5的新特性了解下就行。主要就是看你js掌握的程度,如果稍微要求高一点的,暂时还没面过,等以后面过在来回答

   1. cookie session的用途和区别,以及有效期

   1、cookie数据存放在客户的浏览器上,session数据放在服务器上。

   2、cookie不是很安全,别人可以分析存放在本地的COOKIE并进行COOKIE欺骗

  考虑到安全应当使用session。

   3、session会在一定时间内保存在服务器上。当访问增多,会比较占用你服务器的性能

  考虑到减轻服务器性能方面,应当使用COOKIE。

   4、单个cookie保存的数据不能超过4K,很多浏览器都限制一个站点最多保存20个cookie。

   2. vue的数据绑定原理,mvvm与mvc的区别

   MVVM:

   m:model数据模型层 v:view视图层 vm:ViewModel

   vue中采用的是mvvm模式,这是从mvc衍生过来的

   MVVM让视图与viewmodel直接的关系特别的紧密,就是为了解决mvc反馈不及时的问题

  图片说明一下:

  说到MVVM就要说一下双向绑定和数据劫持的原理,

   MVC:

   m:model数据模型层 v:view视图层 c:controller控制器

  原理: c层需要控制model层的数据在view层进行显示

   MVC两种方式,图片说明:

  总结:

   mvvm与mvc最大的区别:

   MVVM实现了view与model的自动同步,也就是model属性改变的时候,我们不需要再自己手动操作dom元素去改变view的显示,而是改变属性后该属性对应的view层会自动改变。

  不懂得可以复制链接查看:

   https://www.pianshen.com/article/3716256399/

   3. storage的区别 sessionStorage localStorage

   localStorage的生命周期是永久性的。假若使用localStorage存储数据,即使关闭浏览器,也不会让数据消失,除非主动的去删除数据,使用的方法如上所示。localStorage有length属性

   sessionStorage的生命周期是在浏览器关闭前。也就是说,在整个浏览器未关闭前,其数据一直都是存在的。sessionStorage也有length属性,其基本的判断和使用方法和localStorage的使用是一致的

   4.v-model双向数据原理

  有一个文本框通过v-bind绑定了value属性值为myname是我们在vue实例中定义的属性

  传统我们获取文本框值方法可能通过getElementById找到文本框然后获取其value属性

  但是vue中直接通过v-bind绑定了value属性所以不需要像之前那样获取值

  所以在后面的按钮中获取name值直接获取vue实例对象data里面的myname属性即可

  【数据为尊----数据映射到浏览器如果数据v-model后修改(肯定input)然后到数据在有数据映射到浏览器页面----映射关系统称】

   5.keepAlive用过吗?什么作用?

  缓存路由组件

  使用的是vue的一个组件,参考vue的官方文档

  使用这个东西可以保证我们在切换组件的时候,原来显示的组件不被销毁

  -----【保障组件的数据不会被切换路由而销毁数据】

   Home是对应的组件对象的名字,不是路由的名字

   6.多维数组拍平

  数组拍平也称数组扁平化,就是将数组里面的数组打开,最后合并为一个数组

  一红六种方法吧……

  了解的请看: https://www.cnblogs.com/guan-shan/p/10165737.html

   7.跨域的原因解决方案

  跨域是指一个域下的文档或脚本试图去请求另一个域下的资源,这里跨域是广义的。

  这样就可以说同源策略----协议---端口---域名

  原生的src和href可以解决跨域

  代理可以解决

  请求头也可以携带浏览器提示的也可以解决

  一般都是后端解决跨域问题

  【别的需要了解看下方链接】

   https://blog.csdn.net/qq_41604383/article/details/100770100

   8.uniApp兼容问题

  §如果你使用cli创建项目(即项目根目录是package.json),不管用什么ide,即便是用HBuilderX,切记cli项目的编译器是在项目下的,HBuilderX不管怎么升级都不会影响编译器版本。你需要手动npm update来升级编译器。以及如果你想要安装less、scss等预编译器,也需要自己npm安装在项目下,而不是在HBuilderX的插件管理里安装。

  §如果你使用离线打包,请注意HBuilderX升级后,真机运行基座和云打包对应引擎跟随HBuilderX升级,而你的sdk需要手动升级。sdk的版本升级一般滞后HBuilderX正式版升级一两天。

  §如果你使用自定义基座,之前制作的自定义基座是不会跟随HBuilderX升级的,升级HBuilderX后你应该重新制作新版自定义基座。

  §如果你使用wgt升级,新版HBuilderX编译的wgt,运行到之前的runtime上,一定要先测试好,看有没有兼容性问题。如果有问题,就不要wgt升级,整包升级。

  §考虑到向下兼容,uni-app编译器在升级为新的自定义组件模式后,同时保留了对老编译模式的向下兼容。

  在HBuilderX alpha版中,App端一定会使用新编译器,不理会manifest配置。

  在HBuilderX正式版中,新创建的项目会使用新编译器,老项目不会强制使用,而是开发者自己在manifest里配置开启。

  §如果你使用其他ide开发uni-app,会经常因为拼错单词而运行失败,因为经过webpack编译一道,很多错误反应的不够直观,排错时间很长,不如从开始就依赖有良好提示的HBuilderX,避免敲错单词。

  §云打包的引擎版本说明

   HBuilderX Alpha,只有1套云打包机,不管你的HBuilderX alpha版本多少,对应的打包机一定是最新的alpha版的客户端引擎。

   HBuilderX正式版,有2套打包机,一个是最新正式版,一个是次新正式版。

  中间的紧急更新版本没有独立打包机。

  举个例子:

   HBuilderX有1.8.0、1.8.1、1.8.2、1.9.0、1.9.1这几个正式版。

  那么当前可用的打包机有1.9.1和1.8.2这2台。(即每个大版本的最后一个版本)

  除了这2个HBuilderX版本外,其他版本的云打包都指向最新的1.9.1版对应的打包机。(即只保留2个大版本的云打包机)

  【详情请看】

   https://ask.dcloud.net.cn/article/35845

  一、HTML

   HTML书写规范

   H5新增标签

   HTML渲染过程

  二、CSS

   css盒子模型概念

   css弹性布局概念

  三、JavaScript

  事件模型

   DOM2级事件模型

  闭包

  原型链

  四、移动Web开发

  常见的布局方案

  移动端前端常见的触摸相关事件touch、tap、swipe等整理

  移动端前端手势事件

  移动端页面渲染优化

   GPU渲染

   GPU核心渲染过程

  五、调试

  常用的调试工具

   Chrome控制台调试js使用

  移动端测试

  六、HTTP网络知识

  常见的HTTP状态码

  不同请求类型的区别

   WEB缓存方案

  ——————————

  牛客网(www.nowcoder.com)

  -专业IT笔试面试备考平台

  -最全C++JAVA前端等互联网技术求职题库

  -全面提升IT编程能力

  -程序员交友圣地

  分享了一些Web前端的面试题,限时一小时,你看看自己能够答出多少道!

  放心,这些面试题都是一些非常基础的知识,只要你在平时认真听课、学习了,那么这些面试题肯定不会难道你。

  建议:虽然没有人监督你,但还是希望你不要去寻找答案,脱离百度,拿起纸笔,你试一下自己究竟能够答出个什么水平!有没有真本领?答案尽在这些面试题里!那么,你准备好了吗?OK!计时开始!

  一、HTML常见题目

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

   02、HTML5为什么只需要写?

   03、行内元素有哪些?块级元素有哪些?空(void)元素有那些?

   04、页面导入样式时,使用link和@import有什么区别?

   05、介绍一下你对浏览器内核的理解?

   06、常见的浏览器内核有哪些?

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

   08、如何区分HTML和HTML5?

   09、简述一下你对HTML语义化的理解?

   10、HTML5的离线储存怎么使用,工作原理能不能解释一下?

  二、CSS类的题目

   01、介绍一下标准的CSS的盒子模型?与低版本IE的盒子模型有什么不同的?

   02、CSS选择符有哪些?哪些属性可以继承?

   03、CSS优先级算法如何计算?

   04、CSS3新增伪类有那些?

   05、如何居中p?如何居中一个浮动元素?如何让绝对定位的p居中?

   06、display有哪些值?说明他们的作用。

   07、position的值relative和absolute定位原点是?

   08、CSS3有哪些新特性?

   09、请解释一下CSS3的Flexbox(弹性盒布局模型),以及适用场景?

   10、用纯CSS创建一个三角形的原理是什么?

  三、Java类的题目

   01、介绍Java的基本数据类型。

   02、说说写Java的基本规范?

   03、Java原型,原型链?有什么特点?

   04、Java有几种类型的值?(堆:原始数据类型和栈:引用数据类型),你能画一下他们的内存图吗?

   05、Java如何实现继承?

   06、Java创建对象的几种方式?

   07、Java作用链域?

   08、谈谈This对象的理解。

   09、eval是做什么的?

   10、什么是window对象?什么是document对象?

   OK,一小时到了,这个时间可不算短了,那么这些面试题你答出了几道呢?你写的答案正确了吗?现在你可以去翻看答案了。

  如果你答出了绝大多数的或者是全部的题,并且答案也正确了,那么恭喜你……

  你这时心里是不是有点小窃喜,认为自己有能力拿高薪了?虽然我也很想这么告诉你,但事实上这只能表明你的基础扎实,毕竟这只是一些非常基础的面试题。骚年~继续努力吧!

  如果你只答出了小部分或者答出了大部分题但答案不正确,那么我只想说:“骚年,你的水平还差的远呢。”连这么基础的题你都打不出来,还想拿高薪?回去再练一段时间吧!

  扎实的基础是你拿高薪的重要武器,如果你连基础都不扎实,那么想要攻克“高薪”这个厚实的堡垒,那只是痴人说梦罢了。

   1.前端框架类问题,问你会不会用vue react啊

   2.语言类,问你一些JavaScript语言的问题

   3.项目经验,让你讲讲做过的项目,遇到的问题和解决之道

  

面试Web前端需要注意什么会面试哪些问题

  作为一名HTML5前端工程师,为了工作,为了就业我们免不了要参加各种各样的面试。为此总结了面试前的注意事项:

  第一:注意自己的仪容仪表

  面试之前,一定要再次从头到脚地将自己的仪容仪表检查一遍。检查时主要包括,自己的牙缝是不是还有食物残渣,所以你需要就近找一个卫生间,如果没有卫生间就近找一个角落也是可以的,但是切记一定不要在大庭广众之下。因此,为了给自己整理出着装的时间请在约定时间前20分钟到达。

  第二:再次检查面试时所需的资料是否都已带全

  这些资料主要包括:身份证明、学历文凭证明、个人简历、以往作品等等,如果这些东西齐全之后,需要对这些资料做一个整理与排序。因为没有哪个面试官希望看到面试者拿出一堆“莫名其妙”的东西塞给他,让他自己再一页一页的翻找自己需要的内容,如果说这些资料在面试官手中不小心散落一地,结果可想而知。这样的求职者在面试官眼中也一定不是一个让人放心、有条不紊的员工。当然如果检查时发现资料没有带全,也不要紧张。反而你要庆幸幸亏及时检查,也有足够的时间组织语言去向面试官解释。

  第三:面试之前将通信工具调成振动或关闭状态

  虽然说面试者与面试官之间是一个平等的关系,但毕竟你是去人家公司求职的,始终处于一个被动的状态,所以最起码的尊重还是要做到的。曾经有调查显示,对于面试过程中接电话或是被电话打断的求职者,会被HR减分。

  第四:等候面试官时,仔细观察多了解面试公司

  在等候面试官时,可以暗自观察一下公司的大体情况比如员工的着装风格、公司的LOGO或是贴在墙上的企业文化、公司的环境等等,一来可以在接下来的面试过程中表现出自己对公司的认同感,二来也可以让自己对求职公司多些了解,以确定是否要接受这里的工作。如果你身边有公司的资料宣传架,不妨取一本翻看一下,也会增加HR对你的好感。

  第五:放松心情,保持自信

  面试时一定要保持一定的自信,这样也会给面试官留下很好的印象。面试只是你步入工作的第一步,即便是失败了那也是人生重要的经历。失败是为了更好的迎接下一个挑战。

  作为一名web前端工程师千万不要觉得懂技术面试就能万事大吉了,像以上五点细节性的东西也是一定要掌握的。

  面试题系列:

  网页链接

  

web前端面试经常问到的面试题有哪些

  Web前端经常被问到的面试题及答案

  一、HTML+CSS

  1.对WEB标准以及W3C的理解与认识

  标签闭合、标签小写、不乱嵌套、提高搜索机器人搜索几率、使用外

  链css和js脚本、结构行为表现的分离、文件下载与页面速度更快、内容能被更多的用户所访问、内容能被更广泛的设备所访问、更少的代码和组件,容易维

  护、改版方便,不需要变动页面内容、提供打印版本而不需要复制内容、提高网站易用性;

  2.xhtml和html有什么区别

  HTML是一种基本的WEB网页设计语言,XHTML是一个基于XML的置标语言

  最主要的不同:

  XHTML元素必须被正确地嵌套。

  XHTML元素必须被关闭。

  标签名必须用小写字母。

  XHTML文档必须拥有根元素。

  3.Doctype?严格模式与混杂模式-如何触发这两种模式,区分它们有何意义?

  用于声明文档使用那种规范(html/Xhtml)一般为严格过度基于框架的html文档

  加入XMl声明可触发,解析方式更改为IE5.5拥有IE5.5的bug

  4.行内元素有哪些?块级元素有哪些?CSS的盒模型?

  块级元素:div p h1 h2 h3 h4 form ul

  行内元素: a b br i span input select

  Css盒模型:内容,border,margin,padding

  5.CSS引入的方式有哪些? link和@import的区别是?

  内联内嵌外链导入

  区别:同时加载

  前者无兼容性,后者CSS2.1以下浏览器不支持

  Link支持使用javascript改变样式,后者不可

  6.CSS选择符有哪些?哪些属性可以继承?优先级算法如何计算?内联和important哪个优先级高?

  标签选择符类选择符 id选择符

  继承不如指定 Id>class>标签选择

  后者优先级高

  7.前端页面有哪三层构成,分别是什么?作用是什么?

  结构层 Html表示层 CSS行为层 js

  8.css的基本语句构成是?

  选择器{属性1:值1;属性2:值2;……}

  9.你做的页面在哪些流览器测试过?这些浏览器的内核分别是什么?

  Ie(Ie内核)火狐(Gecko)谷歌(webkit) opear(Presto)

  二、Javascript

  1.javascript的typeof返回哪些数据类型

  Object number function boolean underfind

  2.例举3种强制类型转换和2种隐式类型转换?

  强制(parseInt,parseFloat,number)

  隐式(==–===)

  3.split() join()的区别

  前者是切割成数组的形式,后者是将数组转换成字符串

  4.数组方法pop() push() unshift() shift()

  Push()尾部添加 pop()尾部删除

  Unshift()头部添加 shift()头部删除

  5.事件绑定和普通事件有什么区别

  6.IE和DOM事件流的区别

  1.执行顺序不一样、

  2.参数不一样

  3.事件加不加on

  4.this指向问题

  7.IE和标准下有哪些兼容性的写法

  Var ev= ev

   window.event

  document.documentElement.clientWidth

   document.body.clientWidth

  Var target= ev.srcElement

  ev.target

  8.ajax请求的时候get和post方式的区别

  一个在url后面一个放在虚拟载体里面

  有大小限制

  安全问题

  应用不同一个是论坛等只需要请求的,一个是类似修改密码的

  9.call和apply的区别

  Object.call(this,obj1,obj2,obj3)

  Object.apply(this,arguments)

  10.ajax请求时,如何解释json数据

  使用eval parse鉴于安全性考虑使用parse更靠谱

  11.b继承a的方法

  12.写一个获取非行间样式的函数

  function getStyle(obj,attr,value)

  {

  if(!value)

  {

  if(obj.currentStyle)

  {

  return obj.currentStyle(attr)

  }

  else

  {

  obj.getComputedStyle(attr,false)

  }

  }

  else

  {

  obj.style[attr]=value

  }

  }

上海过桥公司

专业办理房产抵押贷款

2020-12-22 12:20

地址:上海浦东新区世纪大道100号71楼

在线微信咨询

电话:17612160507(点击拨打)

微信扫码咨询

相关问题

复制成功
微信号: 13636477376
杭州高端ktv招聘 1500/1800/2000
我知道了