js练习题笔记
javascrip测试题:
一、选择题(每题2分,多选题错选、少选不得分)
1、分析下段代码输出结果是( )
var arr = [2,3,4,5,6];
var sum =0;
for(var i=1;i < arr.length;i++) {
sum +=arr[i] }
console.log(sum);
A.20 B.18 C.14 D.12
2、以下关于 Array 数组对象的说法不正确的是( )
A.对数组里数据的排序可以用 sort 函数,如果排序效果非预期,可以给 sort 函数加一个排序函数的参数
B.reverse 用于对数组数据的倒序排列
C.向数组的最后位置加一个新元素,可以用 pop 方法
D.unshift 方法用于向数组删除第一个元素
3、以下代码运行的结果是输出( )
var a = b = 10;
(function(){
var a=b=20
})();
console.log(b);
A.10 B.20 C.报错 D.undefined
4、以下代码运行后的结果是输出( )
var a=[1, 2, 3];
console.log(a.join());
A.123 B.1,2,3 C.1 2 3 D.[1,2,3]
5、在 JS 中,’1555’+3 的运行结果是( )
A.1558 B.1552 C.15553 D.1553
6、以下代码运行后弹出的结果是( )
var a = 888;
++a;
alert(a++);
A.888 B.889 C.890 D.891
7、关于变量的命名规则,下列说法正确的是( )
A.首字符必须是大写或小写的字母,下划线(_)或美元符($)
B.除首字母的字符可以是字母,数字,下划线或美元符
C.变量名称不能是保留字
D.长度是任意的
E.区分大小写
8、下列的哪一个表达式将返回值为假( )
A.!(3<=1)
B.(4>=4)&&(5<=2)
C.(“a”==“a”)&&(“c”!=“d”)
D.(2<3)||(3<2)
9、下面代码,k的运行结果是( )
var i = 0,j = 0;
for(;i<10,j<6;i++,j++){
k = i + j;
}
A.16 B.10 C.6 D.12
10、var x = 1; function fn(n){n = n+1}; y = fn(x); y 的值为( )
A.2 B.1 C.3 D.undefined
11、[1,2,3,4].join('0').split('') 的执行结果是( )
A.'1,2,3,4'
B.[1,2,3,4]
C.[“1”,“0”,“2”,“0”,“3”,“0”,“4”]
D.'1,0,2,0,3,0,4'
12、下面代码的运行结果是:第一次弹( )第二次弹( )
function fn1() {
alert(1);
}
alert( fn1() );
A.1
B.alert(1);
C.function fn1() { alert(1); }
D.undefined
13,以下代码运行后,结果为( )
fn1();
var fn1 = function(a){ alert(a); }
A.1 B.程序报错 C.alert(1); D.undefined
14,var n = "miao wei ke tang".indexOf("wei",6);n的值为:( )
A.-1 B.5 C.程序报错 D.-10
15,下面对 substring() 方法描述不正确的是( )
A.一共有两个参数,省略第二个参数表示从参数开始位置提、截取到字符串结束。
B.提取之前会比较两个参数的大小,并根据大小调整位置。
C.可以接收负数参数,负数表示从后往前数字符位置。
D.如果没有设置参数,直接返回整个字符串。
16,alert( "12">"9" ) 的运行结果正确的是( )
A.true B.false
17,下面的描述中不正确的是( )
A.arguments 中保存了实际传入函数内的所有参数。
B.return 只能在函数内部使用。
C.setInterval(fn1,1000) 只会调用一次 fn1。
D.Date 对象的 getMonth() 获取到的值比实际月份小1。
18,下面的等式成立的是( )
A.parseInt(12.5) == parseFloat(12.5)
B.Number('') == parseFloat('')
C.isNaN('abc') == NaN
D.typeof NaN === 'number'
19,下面的描述中不正确的是( )
A.'==' 在比较过程中,不但会比较两边的值,还会比较两边的数据类型。
B.NaN == NaN 的结果是 true。
C.isNaN,判断传入的参数是否为数字,为数字返回true,否则返回false
D.字符串的 length 只可以获取,不可以设置。
20,以下代码中,会出现什么结果:第一次弹( ),第二次弹( ),第三次弹( )
function fn1() {
var a = 0;
function fn2() { ++a; alert(a); }
return fn2;
}
fn1()();
var newFn = fn1();
newFn();
newFn();
A.1 B.2 C.0 D.3
21,下面代码的运行结果是:第一次弹( ),第二次弹( )
var a = 100;
function fn1() {
alert(a);
var a = 10;
}
alert( fn1() );
A.100
B.10
C.function fn1() { alert(1); }
D.undefined
22,以下代码运行后,arr的结果为( ),arr2的结果为( )
var arr = [1,2];
var arr2 = arr.concat();
arr2.push( arr.splice(1,0) );
A.[1,2] B.[1,2,[2]] C.[1,2,[]] D.[1,2,3]
23,下面关于数组的描述正确的是( )
A.数组的 length 既可以获取,也可以修改。
B.调用 pop() 方法,不会修改原数组中的值。
C.shift() 方法的返回值是新数组的长度。
D.调用 concat() 方法,会修改原数组的值。
24,下列程序中alert按顺序分别弹出:( ),( ),( )
var a = 10;
function test() {
a = 100;
alert(a);
alert(this.a);
var a;
alert(a);
}
test();
A.10 B.100 c.undefined D.程序报错
25,分析下面的代码,输出的结果是( )
var arr=new Array(5);
arr[1]=1;
arr[5]=2;
console.log(arr.length);
A.2 B.5 C.6 D.报错
26,在JavaScript中,下列( )语句能正确获取系统当前时间的小时值。
A.var date=new Date(); var hour=date.getHour();
B.var date=new Date(); var hour=date.gethours();
C.var date=new date(); var hour=date.getHours();
D.var date=new Date(); var hour=date.getHours();
27,请选择结果为真的选项( )
A.null == undefined
B.null === undefined
C.undefined == false
D.NaN == NaN
28, Math.ceil(-3.14)的结果是( ),Math.floor(-3.14) 的结果是( )
A.-3.14 B.-3 C.-4 D.3.14
29, 阅读以下代码,在页面中结果是( )
var s="abcdefg";
alert(s.substring(1,2));
A.a B.b C.bc D.ab
30, 以下 ECMAScript 变量命名格式正确的是( )
A._125dollor B.1207A C.-dollor D.this
二、问答题(每题8分)
1,找到数组 [-1,-2,1,10,4,5,8] 中的最大值,至少写出两种方法?
2,封装一个函数,将字符串 "miao-wei-ke-tang" 从第二个单词开始首字母大写,然后拼成字符串 miaoWeiKeTang,并返回。(注意:封装成一个函数)
3 , 封装一个函数,将字符串 " miao v " 实现 trim 的功能,但不使用 trim 方法,去掉字符串前后空格,返回处理后的字符串。
4,写一个方法,找出字符串 "abcabcabcabcabcabda" 中 "ab" 出现的次数和位置。
5 ,请用 js 代码完成下列需求:body 里生成 100 个 div,每个 div 宽 100px,高 100px,内容是 1-100 自身序号,颜色按红、黄、蓝、绿交替变色,10行10列排列。
以上的测试题,有没有不会的同学呢? 要是有一半以上你都答不出来的话,或许你该认真考虑进行一次全面系统深入的 JavaScript 学习了~
好啦,答案即将揭晓!
注意哦,不要先看下面的答案,还是自己先检测一下再看答案哦~~
- 答案如下 -
一、选择题答案:(每题2分,多选题错选、少选不得分)
1、B
2、CD
3、B
4、B
5、C
6、B
7、ABCDE
8、B
9、B
10、D
11、C
12、第一次弹( A )第二次弹( D )
13、B
14、A
15、C
16、B
17、C
18、D
19、ABC
20、第一次弹( A ),第二次弹( A ),第三次弹( B )
21、第一次弹( D ),第二次弹( D )
22、arr 的结果为( A ),arr2 的结果为( C )
23、A
24、按顺序分别弹出( B ),( A ),( B )
25、C
26、D
27、A
28、Math.ceil(-3.14) 的结果是( B ),Math.floor(-3.14) 的结果是( C )
29、B
30、A
二、问答题答案:(每题8分)
1、找到数组 [-1, -2, 1, 10, 4, 5, 8] 中的最大值,至少写出两种方法?
var arr = [-1, -2, 1, 10, 4, 5, 8];
// 第一种
var max1 = Math.max.apply(null, arr);
// 第二种
var max2 = arr.sort(function(a, b){
return b - a;
})[0];
// 第三种
var max3 = -Infinity;
for (var i = 0; i < arr.length; i++) {
if (max3 < arr[i]) {
max3 = arr[i];
}
}
2、封装一个函数,将字符串 "miao-wei-ke-tang" 从第二个单词开始首字母大写,然后拼成字符串 miaoWeiKeTang,并返回。(注意:封装成一个函数)
var str = 'miao-wei-ke-tang';
function toTuoFeng(str) {
var arrStr = str.split('-');
for (var i = 1; i < arrStr.length; i++) {
arrStr[i] = arrStr[i].substr(0, 1).toUpperCase() + arrStr[i].substr(1);
}
return arrStr.join('');
}
console.log(toTuoFeng(str));
3、封装一个函数,将字符串 " miao v " 实现 trim 的功能,但不使用 trim 方法,去掉字符串前后空格,返回处理后的字符串。
var str = ' miao v ';
// 第一种方法
function trim(str) {
var start, end;
for (var i=0; i < str.length; i++) {
if (str[i] !== '') {
start = i;
break;
}
}
for (var i = str.length-1; i >= 0; i--) {
if (str[i] !== '') {
end = i;
break;
}
}
return str.substring(start, end + 1);
}
// 第二种方法
function trim(str) {
var start = 0, end = str.length - 1;
while(start < end && str[start] == '') {
start++;
}
while(start < end && str[end] == '') {
end--;
}
return str.substring(start, end + 1);
}
console.log(trim(str));
4、写一个方法,找出字符串 "abcabcabcabcabcabda" 中 "ab" 出现的次数和位置。
var str = 'abcabcabcabcabcabda';
var arr = [];
var n = 0;
while(str.indexOf('ab',n) != -1 && n < str.length) {
arr.push(str.indexOf('ab', n));
n = str.indexOf('ab', n) + 2;
}
console.log(arr);
5、请用 JS 代码完成下列需求:body 里生成 100 个 div,每个 div 宽 100px,高 100px,内容是 1-100 自身序号,颜色按红、黄、蓝、绿交替变色,10 行 10 列排列。
- CSS -
.box { position:relative; }
.box div { width: 60px; height: 60px; position: absolute; }
- HTML -
< div class="box"></div>
- JavaScript -
var box = document.getElementsByTagName('div')[0];
var str = '';
var arr = ['red', 'yellow', 'blue', 'green'];
for (var i = 0; i < 100; i++) {
str += ' < div style="left:' + i%10*60 + 'px; top:' + Math.floor(i/10)*60 + 'px; background:' + arr[i%arr.length] + ';">' + (i+1) + '</div>';
}
box.innerHTML += str;
没事只做了这套题的选择题,结果都错了好多,不过也没什么,现在还处于学习的最基础阶段,只要每天都能进步一点就好了,下面是我做完选择题的笔记:
1.我们可以使用charCodeAt()方法来查看某个数的字符编码,如:‘1’.charCodeAt(0) = 49; ‘9’.charCodeAt(0) = 57。
2.js中字符串的比较只会比较第一个字符,比如‘12’和‘9’:‘1’的字符编码为49,而‘9’的字符编码为57,57>49所以alert(‘12’<‘9’)的值为true。
3.js中使用push来向数组或者字符串的后面添加元素,使用unshift来向数组或者字符串的前面添加元素;而使用pop来从数组或者字符串后面删除元素,用shift从数组或者字符串前面删除元素。
4.js同java一样,是区分大小写的,而且变量的命名规则和java差不多,只能以下划线_,美元符号$,字符开头。
5.Date对象使用getMonth()方法来获取到得月数比实际月份少1。
6.isNaN()方法的值是boolean类型的。
7.Number("")的值为0;parseFloat("")的值为NaN,parseInt("")的值为NaN。
8.typeof NaN === 'number'的值为true.
9.闭包中的局部变量会在内存中一直保存,函数调用之后不会自动清除的。
10.数组中concat , join , slice三个方法会返回新的数组,而其他的方法不会返回新的数组,他们都会改变原数组。
11.splice(1,0)的意思就是从index为1处开始删除0个元素,所以如果var a = splice(1,0) //a = [].
12.数组的length既可以读取,也可以修改的,但是字符串的length只可以读取,不可以修改的。
13.null == undefined的结果为true,null === undefined的结果为false,NaN == NaN的结果为false。
14.Math.ceil():不管是正数还是负数,它都是往大的整数变,比如:Math,ceil(-3.4) = -3,Math.ceil(3.4) = 4。
15.Math.floor():不管是正数还是负数,它都是往小的整数变,比如:Math.floor(-3.4) = -4,Math.floor(3.4) = 3。
16.Math.round():如果是正数的话就是四舍五入,但是如果是负数的话就是五舍六入。
js练习题笔记的更多相关文章
- js学习笔记:webpack基础入门(一)
之前听说过webpack,今天想正式的接触一下,先跟着webpack的官方用户指南走: 在这里有: 如何安装webpack 如何使用webpack 如何使用loader 如何使用webpack的开发者 ...
- Vue.js学习笔记(2)vue-router
vue中vue-router的使用:
- js读书笔记
js读书笔记 基本类型的基本函数总结 1. Boolean() 数据类型 转换为true的值 转换为false的值 Boolean true false String 任何非空字符串 "&q ...
- React.js入门笔记
# React.js入门笔记 核心提示 这是本人学习react.js的第一篇入门笔记,估计也会是该系列涵盖内容最多的笔记,主要内容来自英文官方文档的快速上手部分和阮一峰博客教程.当然,还有我自己尝试的 ...
- JS 学习笔记--9---变量-作用域-内存相关
JS 中变量和其它语言中变量最大的区别就是,JS 是松散型语言,决定了它只是在某一个特定时间保存某一特定的值的一个名字而已.由于在定义变量的时候不需要显示规定必须保存某种类型的值,故变量的值以及保存的 ...
- node.js系列笔记之node.js初识《一》
node.js系列笔记之node.js初识<一> 一:环境说明 1.1 Linux系统CentOS 5.8 1.2 nodejs v0.10.15 1.3 nodejs源码下载地址 htt ...
- JS面向对象笔记二
菜单导航,<JS面向对象笔记一>, 参考书籍:阮一峰之<JavaScript标准参考教程> 一.构造函数和new命令 二.this关键字 三.构造函数和new命令 四.构造函 ...
- WebGL three.js学习笔记 使用粒子系统模拟时空隧道(虫洞)
WebGL three.js学习笔记 使用粒子系统模拟时空隧道 本例的运行结果如图: 时空隧道demo演示 Demo地址:https://nsytsqdtn.github.io/demo/sprite ...
- WebGL three.js学习笔记 法向量网格材质MeshNormalMaterial的介绍和创建360度全景天空盒的方法
WebGL学习----Three.js学习笔记(5) 点击查看demo演示 Demo地址:https://nsytsqdtn.github.io/demo/360/360 简单网格材质 MeshNor ...
随机推荐
- 使用logrotate做nginx日志分割
版权申明:转载请注明出处. 文章来源:http://bigdataer.net/?p=266 背景 nginx是一款非常优秀的网络代理工具,但是其日志管理有点缺憾:nginx的access_log会无 ...
- servlet的补充
1 request client获得请求. response 设置client响应2 text/html13123 不明确的响应用下载处理.3 MIME类型不明确在w3shool4 两种写utf-8的 ...
- 第11章:最长公共子序列(LCS:Longest Common Subsequence)
方法:动态规划 <算法导论>P208 最优子结构 + 重叠子问题 设xi,yi,为前i个数(前缀) 设c[i,j]为xi,yi的LCS的长度 c[i,j] = 0 (i ==0 || j ...
- spring3: 切面及通知实例 Aspectj的aop
1.前置通知 接口: package chapter1.server; public interface IHelloService { public void sayAdvisorBefore(St ...
- javascript简单介绍总结(二)
JavaScript 函数函数是由事件驱动的或者当它被调用时执行的可重复使用的代码块.JavaScript 函数语法函数就是包裹在花括号中的代码块,前面使用了关键词 function:function ...
- 装饰类——wpf
decorator:在元素“周围”设置外边框.背景或者二者. adorner:在已存在的Visual “之上”叠加Visual. AdornerDecorator:为可视化树中其下面的元素提供一个装 ...
- zoj3195倍增lca
求三点之间的最短路,,分别求两点之间的lca除2即可(代码写的太挫了,wa了14发= =) #include<map> #include<set> #include<cm ...
- 小米手机调试出现DELETE_FAILED_INTERNAL_ERROR Error while Installing APKs
小米手机就是这样子,权限什么的总是做的比较严格,去开发者选项里面找答案,看了下很多都是以前的,在最底下发现了一个选项“启用MIUI优化”,其实一般手机的开发者选项里面是不会有这个选项的.关掉该选项,重 ...
- urllib2打开URL(含中文)的问题
import urllib2 url = u"http://www.baidu.com/wd=测试" urllib2.urlopen(url.encode('utf-8')).re ...
- Lucene快速入门
1. 什么是lucene lucene是Apache的一个全文检索工具,使用lucene能快速实现全文检索功能.Lucene是一个工具包,你可以调用它的函数, 但它不能独立运行,不单独对外提供服务. ...