js练习题(二)
发布日期:2021-06-29 12:06:05 浏览次数:3 分类:技术文章

本文共 6176 字,大约阅读时间需要 20 分钟。

js练习题

一. 选择题

  1. 分析下段代码输出结果是( ). B
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
  1. [多选]以下关于 Array 数组对象的说法不正确的是( ). CD

    A. 对数组里数据的排序可以用 sort 函数,如果排序效果非预期,可以给 sort 函数加一个排序函数的参数
    B. reverse 用于对数组数据的倒序排列
    C. 向数组的最后位置加一个新元素,可以用 pop 方法
    D. unshift 方法用于向数组删除第一个元素

  2. 以下代码运行的结果是输出( ). B

var a = b = 10; 	(function(){
var a=b=20; })(); console.log(b);
A. 10     B. 20     C. 报错     D. undefined
  1. 以下代码运行后的结果是输出( ). B
var a=[1, 2, 3];	console.log(a.join());
A. 123     B. 1,2,3     C. 1  2  3     D. [1,2,3]
  1. 在 JS 中,’1555’+3 的运行结果是( ). C

    A. 1558 B. 1552 C. 15553 D. 1553

  2. 以下代码运行后弹出的结果是( ). B

var a = 888;	++a;	alert(a++);
A. 888     B. 889     C. 890     D. 891
  1. [多选]关于变量的命名规则,下列说法正确的是( ). ABCDE

    A. 首字符必须是大写或小写的字母,下划线(_)或美元符($)
    B. 除首字母的字符可以是字母,数字,下划线或美元符
    C. 变量名称不能是保留字
    D. 长度是任意的
    E. 区分大小写

  2. 下列的哪一个表达式将返回值为假( ). B

    A. !(3 <= 1)
    B. (4 >= 4) && (5 <= 2)
    C. (“a” == “a”) && (“c” != “d”)
    D. (2 < 3) || (3 < 2)

  3. 下面代码,k的运行结果是( ). B

var i = 0,j = 0;	for(i<10,j<6;i++,j++){
k = i + j; }
A. 16     B. 10     C. 6     D. 12
  1. var x = 1; function fn(n){n = n+1}; y = fn(x); y 的值为( ). D

    A. 2 B. 1 C. 3 D. undefined

  2. [1,2,3,4].join(‘0’).split(’’) 的执行结果是( ). C

    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’

  3. 下面代码的运行结果是:第一次弹( )第二次弹( ) 第一次弹( A )第二次弹( D )

function fn1() {
alert(1); } alert( fn1() );
A. 1     B. alert(1);     C. function fn1() { alert(1); }      D. undefined
  1. 以下代码运行后,结果为( ). B
fn1();	var fn1 = function(a){
alert(a); }
A. 1     B. 程序报错     C. alert(1);     D. undefined
  1. var n = "miao wei ke tang".indexOf("wei",6); n的值为( ). A

    A. -1 B. 5 C. 程序报错 D. -10

  2. 下面对 substring() 方法描述不正确的是( ). C

    A. 一共有两个参数,省略第二个参数表示从参数开始位置提、截取到字符串结束
    B. 提取之前会比较两个参数的大小,并根据大小调整位置
    C. 可以接收负数参数,负数表示从后往前数字符位置
    D. 如果没有设置参数,直接返回整个字符串

  3. alert( “12”>“9” ) 的运行结果正确的是( ). B

    A. true
    B. false

  4. 下面的描述中不正确的是( ). C

    A. arguments 中保存了实际传入函数内的所有参数
    B. return 只能在函数内部使用
    C. setInterval(fn1,1000) 只会调用一次 fn1
    D. Date 对象的 getMonth() 获取到的值比实际月份小1

  5. 下面的等式成立的是( ). D

    A. parseInt(12.5) == parseFloat(12.5)
    B. Number(’’) == parseFloat(’’)
    C. isNaN(‘abc’) == NaN
    D. typeof NaN === ‘number’

  6. [多选]下面的描述中不正确的是( ). ABC

    A. ‘==’ 在比较过程中,不但会比较两边的值,还会比较两边的数据类型
    B. NaN == NaN 的结果是 true
    C. isNaN,判断传入的参数是否为数字,为数字返回true,否则返回false
    D. 字符串的 length 只可以获取,不可以设置

  7. 以下代码中,会出现什么结果:第一次弹( ).第二次弹( ).第三次弹( ). 第一次弹( A ),第二次弹( A ),第三次弹( B )

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
  1. 下面代码的运行结果是:第一次弹( ).第二次弹( ). 第一次弹( D ),第二次弹( D )
var a = 100;    function fn1() {
alert(a); var a = 10; } alert( fn1() );
A. 100B. 10C. function fn1() { alert(1); }D. undefined
  1. 以下代码运行后,arr的结果为( ).arr2的结果为( ). arr 的结果为( A ),arr2 的结果为( C )
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]
  1. 下面关于数组的描述正确的是( ). A

    A. 数组的 length 既可以获取,也可以修改
    B. 调用 pop() 方法,不会修改原数组中的值
    C. shift() 方法的返回值是新数组的长度
    D. 调用 concat() 方法,会修改原数组的值

  2. 下列程序中alert按顺序分别弹出( ),( ),( ) 分别弹出( B ),( A ),( B )

var a = 10;  	function test() {
a = 100; alert(a); alert(this.a); var a; alert(a); } test();
A. 10     B. 100     c. undefined     D. 程序报错
  1. 分析下面的代码,输出的结果是( ). C
var arr=new Array(5); 	arr[1]=1; 	arr[5]=2;	console.log(arr.length);
A. 2     B. 5     C. 6     D. 报错
  1. 在JavaScript中,下列语句能正确获取系统当前时间的小时值( ). D

    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();

  2. 请选择结果为真的选项( ). A

    A. null == undefined
    B. null === undefined
    C. undefined == false
    D. NaN == NaN

  3. Math.ceil(-3.14)的结果是( ), Math.floor(-3.14) 的结果是( ). B C

    A. -3.14
    B. -3
    C. -4
    D. 3.14

  4. 阅读以下代码,在页面中结果是( ). B

var  s="abcdefg";	alert(s.substring(1,2));
A. a     B. b     C. bc     D. ab
  1. 以下 ECMAScript 变量命名格式正确的是( ). A
    A. _125dollor
    B. 1207A
    C. -dollor
    D. this

二. 问答题

  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]; }}
  1. 封装一个函数,将字符串 “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));
  1. 封装一个函数,将字符串 " 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));
  1. 写一个方法,找出字符串 “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);
  1. 请用 JS 代码完成下列需求:body 里生成 100 个 div,每个 div 宽 100px,高 100px,内容是 1-100 自身序号,颜色按红、黄、蓝、绿交替变色,10 行 10 列排列
.box{
position:relative;}.box div{
width: 60px; height: 60px; position: absolute;}
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) + '';}box.innerHTML += str;

转载地址:https://blog.csdn.net/ZZZ___jh/article/details/109518485 如侵犯您的版权,请留言回复原文章的地址,我们会给您删除此文章,给您带来不便请您谅解!

上一篇:九九乘法表
下一篇:js练习题

发表评论

最新留言

第一次来,支持一个
[***.219.124.196]2024年04月29日 06时21分31秒