Web前端基础⾯试题⽬及答案特斯拉model3二手车价格
前端基本技能有:1 HTML/CSS; 2 JavaScript
1、什么是盒⼦模型?
在⽹页中,⼀个元素占有空间的⼤⼩由⼏个部分构成,其中包括元素的内容(content),元素的内边距(padding),元素的边框(border),元素的外边距(margin)四个部分。这四个部分占有的空间中,有的部分可以显⽰相应的内容,⽽有的部分只⽤来分隔相邻的区域或区域。4个部分⼀起构成了css中元素的盒模型。
2、⾏内元素有哪些?块级元素有哪些?空(void)元素有那些?
⾏内元素:a、b、span、img、input、strong、select、label、em、button、textarea 块级元素:div、ul、li、dl、dt、dd、p、h1-h6、blockquote 空元素:即系没有内容的HTML元素,例如:br、meta、hr、link、input、img
3、CSS实现垂直⽔平居中
⼀道经典的问题,实现⽅法有很多种,以下是其中⼀种实现: HTML结构:
<div class="wrapper">
<div class="content"></div>
</div>
CSS:
.wrapper{position:relative;}.content{
background-color:#6699FF;
width:200px;
height:200px;
position: absolute;        //⽗元素需要相对定位
top: 50%;
left: 50%;
margin-top:-100px ;  //⼆分之⼀的height,width
margin-left: -100px;}
4、简述⼀下src与href的区别
href 是指向⽹络资源所在位置,建⽴和当前元素(锚点)或当前⽂档(链接)之间的链接,⽤于超链接。
src是指向外部资源的位置,指向的内容将会嵌⼊到⽂档中当前标签所在位置;在请求src资源时会将其指向的资源下载并应⽤到⽂档内,例如js脚本,img图⽚和frame等元素。当浏览器解析到该元素时,会暂停其他资源的下载和处理,直到将该资源加载、编译、执⾏完毕,图⽚和框架等元素也如此,类似于将所指向资源嵌⼊当前标签内。这也是为什么将js脚本放在底部⽽不是头部。
5、什么是CSS Hack?
⼀般来说是针对不同的浏览器写不同的CSS,就是 CSS Hack。
IE浏览器Hack⼀般⼜分为三种,条件Hack、属性级Hack、选择符Hack(详细参考CSS⽂档:css⽂档)。例如:
// 1、条件Hack
<!--[if IE]>
<style>
.test{color:red;}
</style>
<![endif]-->
// 2、属性Hack
.test{
color:#090\9; / For IE8+ /
color:#f00; / For IE7 and earlier /
_color:#ff0; / For IE6 and earlier */
}
// 3、选择符Hack
html .test{color:#090;} / For IE6 and earlier /
html .test{color:#ff0;} / For IE7 /
6、简述同步和异步的区别
同步是阻塞模式,异步是⾮阻塞模式。
同步就是指⼀个进程在执⾏某个请求的时候,若该请求需要⼀段时间才能返回信息,那么这个进程将会⼀直等待下去,直到收到返回信息才继续执⾏下去;
异步是指进程不需要⼀直等下去,⽽是继续执⾏下⾯的操作,不管其他进程的状态。当有消息返回时系统会通知进程进⾏处理,这样可以提⾼执⾏的效率。
7、px和em的区别
px和em都是长度单位,区别是,px的值是固定的,指定是多少就是多少,计算⽐较容易。em得值不
是固定的,并且em会继承⽗级元素的字体⼤⼩。
浏览器的默认字体⾼都是16px。所以未经调整的浏览器都符合: 1em=16px。那么12px=0.75em, 10px=0.625em
8、什么叫优雅降级和渐进增强?
渐进增强 progressive enhancement:
针对低版本浏览器进⾏构建页⾯,保证最基本的功能,然后再针对⾼级浏览器进⾏效果、交互等改进和追加功能达到更好的⽤户体验。
优雅降级 graceful degradation:
⼀开始就构建完整的功能,然后再针对低版本浏览器进⾏兼容。
区别:
a. 优雅降级是从复杂的现状开始,并试图减少⽤户体验的供给
web套壳app
b. 渐进增强则是从⼀个⾮常基础的,能够起作⽤的版本开始,并不断扩充,以适应未来环境的需要
c. 降级(功能衰减)意味着往回看;⽽渐进增强则意味着朝前看,同时保证其根基处于安全地带
9、浏览器的内核分别是什么?
IE: trident内核
Firefox:gecko内核
web前端基础面试题Safari:webkit内核
Opera:以前是presto内核,Opera现已改⽤Google Chrome的Blink内核
Chrome:Blink(基于webkit,Google与Opera Software共同开发)
JavaScript部分
1、怎样添加、移除、移动、复制、创建和查节点?
1)创建新节点
createDocumentFragment() //创建⼀个DOM⽚段罗马夺欧协联冠军
createElement() //创建⼀个具体的元素
createTextNode() //创建⼀个⽂本节点
2)添加、移除、替换、插⼊
appendChild() //添加
removeChild() //移除
replaceChild() //替换
insertBefore() //插⼊
3)查
getElementsByTagName() //通过标签名称
js登录注册界面代码
getElementsByName() //通过元素的Name属性的值
getElementById() //通过元素Id,唯⼀性
2、实现⼀个函数clone,可以对JavaScript中的5种主要的数据类型(包括Number、String、Object、Array、Boolean)进⾏值复制。
3、如何消除⼀个数组⾥⾯重复的元素?
4、想实现⼀个对页⾯某个节点的拖曳?如何做?(使⽤原⽣JS )。
5、在Javascript 中什么是伪数组?如何将伪数组转化为标准数组?
伪数组(类数组):⽆法直接调⽤数组⽅法或期望length 属性有什么特殊的⾏为,但仍可以对真正数组遍历⽅法来遍历它们。典型的是函数的argument 参数,还有像调⽤getElementsByTagName,document.childNodes 之类的,它们都返回NodeList 对象都属于伪数组。可以使⽤Array.prototype.slice.call(fakeArray)将数组转化为真正的Array 对象。
6、Javascript 中callee 和caller 的作⽤?
caller 是返回⼀个对函数的引⽤,该函数调⽤了当前函数;
callee 是返回正在被执⾏的function 函数,也就是所指定的function 对象的正⽂。
7、请描述⼀下cookies ,sessionStorage 和localStorage 的区别组织机构代码生成器在线
sessionStorage ⽤于本地存储⼀个会话(session )中的数据,这些数据只有在同⼀个会话中的页⾯才能访问并且当会话结束后数据也随之销毁。因此sessionStorage 不是⼀种持久化的本地存储,仅仅是会话级别的存储。⽽localStorage ⽤于持久化的本地存储,除⾮主动删除数据,否则数据是永远不会过期的。
web storage 和cookie 的区别
Web Storage 的概念和cookie 相似,区别是它是为了更⼤容量存储设计的。Cookie 的⼤⼩是受限的,并且每次你请求⼀个新的页⾯的时候Cookie 都会被发送过去,这样⽆形中浪费了带宽,另外cookie
还需要指定作⽤域,不可以跨域调⽤。
// ⽅法⼀:var arr1 =[1,2,2,2,3,3,3,4,5,6],
arr2 = [];for(var i = 0,len = arr1.length; i< len; i++){
if(arr2.indexOf(arr1[i]) < 0){
arr2.push(arr1[i]);    }}document.write(arr2); // 1,2,3,4,5,6
function log(){
var args = Array.prototype.slice.call(arguments);  //为了使⽤unshift 数组⽅法,将argument 转化为真正的数组
args.unshift('(app)');
console.log.apply(console, args);};
除此之外,Web Storage拥有setItem,getItem,removeItem,clear等⽅法,不像cookie需要前端开发者⾃⼰封装setCookie,getCookie。但是Cookie也是不可以或缺的:Cookie的作⽤是与服务器进⾏交互,作为HTTP规范的⼀部分⽽存在,⽽Web Storage仅仅是为了在本地“存储”数据⽽⽣。
8、⼿写数组快速排序
关于快排算法的详细说明,可以参考阮⼀峰⽼师的⽂章快速排序
“快速排序”的思想很简单,整个排序过程只需要三步:
(1)在数据集之中,选择⼀个元素作为”基准”(pivot)。
(2)所有⼩于”基准”的元素,都移到”基准”的左边;所有⼤于”基准”的元素,都移到”基准”的右边。
(3)对”基准”左边和右边的两个⼦集,不断重复第⼀步和第⼆步,直到所有⼦集只剩下⼀个元素为⽌。
9、统计字符串”aaaabbbccccddfgh”中字母个数或统计最多字母数。
var str = "aaaabbbccccddfgh";var obj = {};for(var i=0;i<str.length;i++){var v = str.charAt(i);if(obj[v] && obj[v].value == v){obj[v].count = ++
obj[v].count;}else{obj[v] = {};obj[v].count = 1;obj[v].value = v;}}for(key in obj){document.write(obj[key].value +'='+obj[key].count+' '); // a=4 b=3 c=4 d=2 f=1 g=1 h=1}
**10、写⼀个function,清除字符串前后的空格。(兼容所有浏览器)**
function trim(str) {
if (str && typeof str === "string") {
place(/(^\s)|(\s)$/g,""); //去除前后空⽩符
}
}
其他
1、⼀次完整的HTTP事务是怎样的⼀个过程?
基本流程:
a. 域名解析
b. 发起TCP的3次握⼿
c. 建⽴TCP连接后发起http请求
d. 服务器端响应http请求,浏览器得到html代码
e. 浏览器解析html代码,并请求html代码中的资源
f. 浏览器对页⾯进⾏渲染呈现给⽤户
2、对前端⼯程师这个职位你是怎么样理解的?
a. 前端是最贴近⽤户的程序员,前端的能⼒就是能让产品从 90分进化到 100 分,甚⾄更好
b. 参与项⽬,快速⾼质量完成实现效果图,精确到1px;
c. 与团队成员,UI设计,产品经理的沟通;
d. 做好的页⾯结构,页⾯重构和⽤户体验;
e. 处理hack,兼容、写出优美的代码格式;
f. 针对服务器的优化、拥抱最新前端技术。

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。