高频前端js面试题(一)

1.介绍 js 的基本数据类型?
Undefined、 Null 、 Boolean 、 Number 、 String
2.怎样判断一个元素是否为一个数组?
方法一:isArray
var arr = [1,2,3];
console.log(Array.isArray(arr));
方法二:instanceof array
var a = new Array();
console.log(a instanceof Array) //true
3.innerHtml与innerText的区别?

1.innerHTML指的是从对象的起始位置到终止位置的所有内容,包括Html标签。css

2.innerText 指的是从起始位置到终止位置的内容,但它去除Html标签。前端

<div id="test">这是一段
    <span>代码</span>
</div>
console.log(document.getElementById('test').innerHtml) //这是一段代码
console.log(document.getElementById('test').innerText) //这是一段<span>代码</span>
4.get与post区别?

1.get 请求经过url传值,post请求经过body传值jquery

2.post请求比get更安全es6

5.js去除重复值?
方法一: es5
Array.prototype.test=function(){
 var arr=[];//建立新数组
 for(var i=0;i<this.length;i++){ //遍历当前数组
 if(arr.indexOf(this[i])===-1){//若是等于-1,那么也是就是新数组中没有一项和当前数组同样
   arr.push(this[i])
}
}
return arr;
}
//调用:ary.test()
方法二:es6
[...new Set([1,1,2,2,3,3])];//[1,2,3]
6.进行性能优化

1,图片懒加载;json

2,浏览器缓存;跨域

3,DNS优化:数组

DNS查询:
    <meta rel='dns-prefetch' href='//cdn.bootcss.com'/>
    <link rel='dns-prefetch' href='//s.happymmall.com'>
    <link rel='dns-prefetch' href='//img.happymmall.com'>
7.跨域及解决跨域的方法?
> 跨域:浏览器对js同源策略的限制。前端调用后台数据域名不同就形成了跨越。

> 同源策略:请求的url必须与服务器上面的url处于同域上。即域名,端口号,协议同样

>  解决跨域:
>  - 1.用基于jquery的jsonp方法经过get请求来解决,不能用post请求
>   -2.用基于script标签实现跨域
8.var,const,let三者区别

1.从做用域的角度:浏览器

  • es5只有全局做用域和函数做用域,没有块级做用域
  • const与let都是块级做用域,var是全局做用域

2.从声明变量角度:缓存

  • const只能声明赋值一次,第二次会报错;
  • let声明的变量只在let命令所在的代码块内有效,let能够重复赋值,可是若是在声明let变量以前使用,会报错

文中的代码可能不必定是最优代码,要是你有更好的代码欢迎评论。喜欢的能够给我点赞鼓励哦!
码字不易,屏幕前的大帅比,更多干货文章请关注!!!安全

更多干货文章请关注

备注:
★部分素材来自网络,版权归原创者,若有侵权请联系删除

本文由博客群发一文多发等运营工具平台 OpenWrite 发布