常见js笔试面试题

本文汇总了常见的JavaScript笔试面试题,涵盖了基础的类型判断、强制类型转换、数组操作、事件处理、面向对象、同源策略、跨域解决方案、垃圾回收、闭包、事件委托等核心知识点,旨在帮助开发者准备面试,提升JS技能。
摘要由CSDN通过智能技术生成

常见js笔试面试题


js基础知识

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

object,string,undefined,number,function,boolean

基本数据类型:
string,number,boolean,undefined,null

2. 列举三种强制类型转换和两种隐式类型转换

parseInt(),parseFloat(),Number()
==,!!

3. 数组相关集合

3.1. 创建数组方法

var array = new Array()
var array = []

Array.of(1,2) //[1,2]
这是es6新增的一个Array方法,创建一个具有可变数量参数的新数组实例,而不考虑参数的数量或类型。
(感谢 haru 的宝贵建议)

4. 判断是否为数组的方法

  • console.log(arr instanceof Array)

  • console.log(arr.construct === Array)

  • console.log(Array.isArray(arr))

5. pop(),push(),unshift(),shift()

  • pop()尾部删除

  • push()尾部插入

  • unshift()头部插入

  • shift()头部删除

6. DOM0 DOM2

dom0级

  • 不支持添加多个事件,后面的会覆盖前面的

  • 无法取消

var btn = document.getElementById("button");
btn.onclick = function(){
    alert(1);
}
btn.onclick = function(){
    alert(2);
}       //只弹出2

dom2

  • 可以添加多个事件

  • 不兼容低版本IE

  • 支持事件冒泡,事件捕获

var btn = document.getElementById("button");
btn.addEventListener("click",function(){
    alert("1");
})
btn.addEventListener("click",function(){
    alert("2");
})              //先弹出1,再弹出2

7. IE和DOM事件流的区别

  • 执行顺序不一样

  • 参数不一样 低版本ie没有回调函数,只能进行冒泡

  • 第一个参数是否加"on",低版本IE不支持addEventListener(),支持attachEvent,第一个参数需要加"on"

  • this指向问题,IE指向windows,不指向触发的函数

8. IE标准下有哪些兼容性写法

var ev = ev||window.event

document.documentElement.clientWidth||document.body.clientWidth

var target = ev.srcElement||ev.target

9. call apply bind

改变this的指向,
其中call的写法

function add(a,b)  
{  
    alert(a+b);  
}  
function sub(a,b)  
{  
    alert(a-b);  
}  
  
add.call(sub,3,1);   

这个例子中的意思就是用 add 来替换 sub,add.call(sub,3,1) == add(3,1) ,所以运行结果为:alert(4); // 注意:js 中的函数其实是对象,函数名是对 Function 对象的引用。
apply写法

function add(a,b)  
{  
    alert(a+b);  
}  
function sub(a,b)  
{  
    alert(a-b);  
}  
add.apply(sub,[4,2]); 

不同就在于第二个参数,apply写成数组

bind写法
function add(a,b) 
{

alert(a+b);


function sub(a,b) 
{


   
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值