js基础面试题1

第一题:

js基础面试题1_第1张图片
知识点

Onkeypress:在文本框中的这个属性表示,在键盘按下并抬起之后触发的事件(绑定函数事件)因为函数当中需要使用事件对象以及绑定当前元素,所以在调用函数back()时,需要在里面传递参数,也就是当前元素,(this表示当前元素),以实参形式传递给back这个函数,

在本题当中的Onkeypress=“back(this,event)”里传递的第二个参数event可以不传,因为当绑定好元素之后,函数当中就已经可以得到事件对象了

Event.returnValue: 通过该属性可以取消事件处理程序中调用函数的默认操作,简单来说就是阻止默认的行为,在这个例子当中把此属性设置为false,阻止了enter自带的操作(换行事件),所以现在你按下enter时不会再进行换行操作,只有字符写满一行时才会自动换行,这里的换行不是enter键起的作用,只是根据容器的大小进行的换行排序

第二题:

js基础面试题1_第2张图片
答案:永远不输出
原因:在这段代码当中,在第一行代码var t=true ,之后用定时器在一秒后更改值为false,
首先SeTtimeout是一个异步执行,不在主线程当中,所以在while循环事件的判断条件中,当t是一个true时,则循环执行,在这个循环事件中由于我们没有给任何限制条件让它去停止循环,所以造成了死循环,主线程卡在这里,无法插入异步行为,所以,代码永远不会输出,甚至会造成电脑崩溃

第三题:

js基础面试题1_第3张图片

在这个解答中Array.prototype.filter.call这个方法的作用分解:

Array.prototype:数组的构造函数的原型,在这里我们可以查看到数组上的方法,也可以用“.”的方法进行使用,这个原型也是一个数组类型,在这里取代被操作的数组
filter():数组当中的一个方法,属于过滤器,括号中是一个回调函数,在回调函数中有三个参数,第一个是遍历到的每一项,第二个是下标,第三个是原数组,根据return出的条件去进行判断,过滤出符合条件的值,再形成一个新的数组

call():这个方法是对this进行重定向,括号中第一个参数表示定义当前this的指向,第二个参数,可以是任意类型,包括函数
所以这里tempArray接收到的是一个返回的新数组,把这个数组再用join方法转换成字符串并用“,”分隔就可以了

function specify(str) {
    str=[...str]
   let s= str.filter((val)=>{
        return val!=","
    })   
    return s.join(",")    
}
console.log(specify("hello,world"));

此题另一种解答方式:在此方法中使用了es6中的新语法,”…” 剩余运算符,这个在这里起到的作用是展开,把str这个字符串展开并转换成了一个新数组,然后用过滤器去掉字符串中多余的“,”,最后再用join方法转换成字符串并用逗号分隔就可以了

你可能感兴趣的:(js基础面试题)