javascript测试题总结

简介:

1.js的几种数据类型?判断基本数据类型的操作符是什么?

 答案:Number,String,bool,undefined,obejct(此处为null类型属于object,所以此处写object)

    typeof

2.列举你知道的JS浏览器兼容问题。

 (1)ie不支持ClassName取标签,非ie支持

 (2) 获取非ie窗口的scrolltop值通过document.body.scrollTop

    获取ie窗口的scrolltop值通过document.documentElement.scrollTop

 (3) 通过childNodes获取子节点,ie不能取到回车节点,非ie可以。

 (4) innerText在火狐中不可用

 (5) addEventListener 非ie支持,attachEvent ie专用

 (6) input标签的type属性在ie6中不可修改

3.setTimeout()和setInterval()的区别以及使用它们需要注意的事项。

setInterval(函数,time) 它从载入后,每隔指定的时间就执行一次表达式(循环执行) ,一般放控制函数外部。

setTimeout(函数,time) 在执行时,是在载入后延迟指定时间后,去执行一次表达式, (只执行一次) ,一般放控制函数内部。

注意:(1) 这两种方法可能看起来非常像,而且显示的结果也会很相似,不过两者的最大区别就是,setTimeout方法不会每隔x秒钟就执行一次函数,它是在每次调用setTimeout后过x秒钟再去执行函数。这意味着如果函数的主体部分需要2秒钟执行完,那么整个函数则要每x+2秒钟才执行一次。而setInterval却没有被自己所调用的函数所束缚,它只是简单地每隔一定时间就重复执行一次那个函数。如果要求在每隔一个固定的时间间隔后就精确地执行某动作,那么最好使用setInterval,而如果不想由于连续调用产生互相干扰的问题,尤其是每次函数的调用需要繁重的计算以及很长的处理时间,那么最好使用setTimeout。

(2) 注意及时清计时器

(3)setTimeout(alert(this),20)/ setInterval(alert(this),20)中this都指向window

(4)不能直接传参

4.字符串转化为整形的方法,整形转化为字符串的方法。

(1)parseInt()、Number();

(2)toString();String();“”;

5.在团队开发中,你是如何避免JS命名冲突的?

(1)闭包    ( function ( ) {  } )

(2) 命名空间

(3)可以开发前规定命名规范,根据不同开发人员开发的功能在函数前加前缀

6.简述一下绑定事件的常见方法,它们有什么特点?

(1)在标签中绑定;

(2)Element.on+type=func;

(3)attachEvent("on"+type,func);

(4)addEventListener(type,func,false); 执行冒泡阶段

  addEventListener(type,func,true); 执行捕获阶段

7.

复制代码
function test(){
    alert(this);
}
test();
var o=['a'];
o.test = test3 =function(){
    alert(this);
}
o.test();
test3();
复制代码

分别弹出什么?为什么?

第一个弹window,函数中this指向window,

第二个弹a,方法中的this指向对象

第三个弹window,test3是一个函数;

8.

复制代码
var a=1;
function test(){
    a++;
    alert(a);
    var a=1;
    alert(a);
}
test();
复制代码

结果是多少?为什么?
第一个弹NaN,a在test()里面找的时候,如果前面没有声明var a;那么a会自动变成var a;但是未赋值,所以是undefined,执行a++的时候会变成NaN,不是一个有效的数值;
第二个弹1,因为声明了变量a=1;所以弹出1;

本文转自挨踢前端博客园博客,原文链接http://www.cnblogs.com/duanhuajian/archive/2012/08/20/2648132.html如需转载请自行联系原作者


@挨踢前端

相关文章
|
2月前
|
JavaScript 前端开发 数据格式
期末测试——JavaScript方式练习题
期末测试——JavaScript方式练习题
52 0
|
5月前
|
JavaScript 前端开发 测试技术
JavaScript测试和调试工具:学习使用测试框架(如Jasmine、Mocha)对JavaScript代码进行单元测试
JavaScript测试和调试工具:学习使用测试框架(如Jasmine、Mocha)对JavaScript代码进行单元测试
|
10月前
|
JavaScript 前端开发 NoSQL
【Node.js实战】一文带你开发博客项目之初识Koa2(koa2安装使用、搭建开发环境、测试路由)
【Node.js实战】一文带你开发博客项目之初识Koa2(koa2安装使用、搭建开发环境、测试路由)
313 0
|
10月前
|
JavaScript 前端开发 BI
JavaScript —— JSchallenger Objects 对象练习(测试一下你的 JS 对象基础)【专题三】
JavaScript —— JSchallenger Objects 对象练习(测试一下你的 JS 对象基础)【专题三】
|
10月前
|
JavaScript 前端开发 网络架构
JavaScript —— JSchallenger Arrays 数组练习(测试一下你的 JS 数组基础)【专题二】
JavaScript —— JSchallenger Arrays 数组练习(测试一下你的 JS 数组基础)【专题二】
|
10月前
|
JavaScript 前端开发 Java
JavaScript —— JSchallenger Basics 基础练习(测试一下你的 JS 基础)【专题一】
JavaScript —— JSchallenger Basics 基础练习(测试一下你的 JS 基础)【专题一】
|
CDN
Vue3.js快速开发CDN引入测试模板
Vue3.js快速开发CDN引入测试模板
359 0
|
前端开发
前端知识案例54-javascript基础语法-数组测试
前端知识案例54-javascript基础语法-数组测试
38 0
前端知识案例54-javascript基础语法-数组测试
|
JavaScript 前端开发 API
JavaScript中字符串的API使用总结
JavaScript中字符串的API使用总结
|
JSON 编解码 JavaScript
【笔记】js URL编码解析总结
js URL编码解析总结
230 0