JavaScript基础练习试卷--答案

JavaScript试卷答案

一、简答题(每题3分)

1. Javascript的组成?

    ECMAScript  DOM  BOM

2. Javascript可以运行在什么地方?

    Node  浏览器

3. Javascript基本数据类型有哪些

    undefined null number string boolean

    //Object--->null 

    //var obj = null;

4. Javascript中的内置对象以及函数有哪些?

    对象:Math Location History document

    函数:Array Object Date String Number Boolean ... RegExp

5.Javascript对象、函数、数组的定义

  对象的定义:

    对象字面量 var obj = {}

    构造函数 var obj = new Object()

  函数的定义:

    函数表达式 var foo = function(){}

    函数声明 function foo(){}

  数组的定义

    数组字面量  var arr = new Array()

    构造函数 var arr = []

6.obj1={name:'lisi'}; obj2=obj1; obj3={name:'lisi'},说明它们三者之间的关系

  obj1 == obj2  true

  obj1 == obj3  false

  obj2 == obj3  false

7. 请写出10个数组实例可以调用的方法

    slice() splice()  join()  toString()  sort() concat() reverse() push()pop() shift() unshift() forEach() some() every() filter() map()

8. 请写出10个字符串实例可以调用的方法

    split() toLowerCase()  toUpperCase() indexOf() lastIndexOf() replace() charAt() trim() match() substr() substring()

9. 请写出Math中常见的5个方法

    ceil() floor() random() max() min()

10. 函数的调用方法有几种?

    test()

    test.call(this,参数列表)

    test.apply(this,参数数组)

11. 解释什么是arguments

    每个函数的内部都有一个局部变量arguments,是用来存放实参的类数组对象

    function test(a,b,c,d){

      //a,b,c,d都是test内的局部变量

      //var a,b,c,d;

      console.log(d);//4

      arguments-->{[1,2,3,4,5,6]}

    }

    test(1,2,3,4,5,6)

12.== 与 ===的区别

    == 比较值

    === 比较类型和值 如果类型不一致,直接返回false

13.typeof的返回值有哪些

  number string boolean undefined function object NaN

14.简述事件流与事件冒泡

    事件流:指从页面中接收事件的顺序,有冒泡流和捕获流。

    事件流是事件执行的顺序,在IE底下是事件冒泡,在非IE底下是事件捕获。

    事件冒泡是:当子元素与父元素都绑定了同一个事件的时候,触发了子元素的事件之后,先执行子元素的事件处理程序,再冒泡执行父元素的事件处理程序

15.为什么要使用阿里云?它在我们开发中扮演什么角色?

    阿里云可以提供一个远程服务器,可以使用它进行linux学习,js学习,也可以用于搭建个人网站。

阿里云等云服务器一般作为项目的部署服务器,需要在阿里云上安装一些项目部署的环境,需要掌握基本的命令操作和vim操作。

16.如何理解DOM对象的事件默认行为?

    有的DOM对象有默认的行为,比如点击a标签跳转,这就是a标签在点击之后的默认行为

17.DOM中怎样追加、插入、移除、复制和获取节点(写出方法名即可)

  appendChild()

  insertBefore()

  removeChild()

  cloneNode()

  document.getElementById()

  document.getElementsByClassName()[0]

  document.getElementsByTagName()[0]

18.我们为一个dom对象绑定了一个事件处理函数,请问谁来调用这个事件处理函数?

    这个dom对象

    div.onclick = function(){

 

    }

    ul.onclick = function(event){

      if(event.target.nodeName=="LI"){

        alert(1);

      }

    }

19.简述事件代理机制?

    给父元素绑定事件,在相应子元素点击的时候触发。

    父元素代理了子元素上的事件, 或者说是子元素委托父元素来触发它上面的事件

20.目前为止,我们学过html,css,js简述这些技术的作用和技术之间的关联性?

    html页面结构

    css 页面样式

    js  页面动作行为

    jQuery 封装了js中的DOM操作和Ajax技术

    bootstrap  封装了 html css js jQuery

21.谈谈你对于原型链的理解?

    js通过原型链来继承,在原型链中的方法,实例可以调用。

22.javascript的迭代方法有哪些

  forEach、every、some、filter、map

23.举例说明值传递和引用传递的区别

  //b 为3    值拷贝

  var a = 3;

  var b = a;   

  b++;

  console.log(a); //3

 

  // a为指针,b为指针  引用拷贝

  var a = {name:"terry",age:12};

  var b = a;   

  b.age++;

  console.log(a.age);  //13

24. 是否使用过github? 你熟悉的git命令有哪些?

    git init   在当前目录新建一个Git代码库

    git clone [url]  下载一个项目和它的整个代码历史

    git add    添加文件到暂存区

    git commit -m [message]  提交暂存区到仓库区

    git status 显示有变更的文件

25. 你使用的服务器的操作系统是?写出20个你用过的linux命令并解释该命令的含义。

  例如:

    声明 $表示为linux操作系统的终端标识

    $ cd [目录]]  切换目录,当目录为空的时候表示进入到家目录

    ...

    ls      展示目录内的内容

    cd ..   打开上一级

    mkdir   创建目录

    rm      删除文件

    cat     查看内部内容

    more    查看内部内容

    vi      打开vi编辑器

    vim     打开vim编辑器

    cp      复制

    ftp     文件传输

    dirs   显示目录记录

    httpd  Apache HTTP服务器程序

    apachectl  控制Apache HTTP服务器的程序

    exit   关闭控制台

    su     用于变更为其他使用者的身份,除 root 外,需要键入该使用者的密码

    sudo   以系统管理者的身份执行指令,也就是说,经由 sudo 所执行的指令就好像是 root 亲自执行。

    who    显示系统中有哪些使用者正在上面

    whoami 用于显示自身用户名称

    whois  用于查找并显示用户信息

    clear  清屏

 

二、编程题 (每题5分)

1. 数组去重

  例如:

    var arr = [1,2,3,4,5,3,4,6,8,1];

    编写程序去除数组内重复的值得到如下结果

    arr = [1,2,3,4,5,6,8]

  答:

   

var arr = [1,2,3,4,5,3,4,6,8,1];
            Array.prototype.myfunction= function(){
                var newArr = [];
                for(var i=0;i<this.length;i++){
                    if(this.indexOf(this[i])==i){
                        newArr[newArr.length]=this[i];
                    }
                }
                return newArr;
            }
            console.log(arr.myfunction());

2. ajax是什么?你在开发中如何使用ajax?(使用原生js语法)

    ajax是异步的JavaScript和XML。用来进行异步请求。浏览器可以向服务器发送一个ajax请求,进行页面的局部刷新。

原生ajax:

//1.创建XMLHttpRequest对象

var httpRequest = new XMLHttpRequest();

//2.配置请求信息,建立连接

httpRequest.open('get', 'http://47.106.244.1:8099/manager/category/findAllCategory');

//3.发送请求

httpRequest.send();

//4.接受响应

httpRequest.onreadystatechange = function () {

// http请求完成,并且状态是200的时候,代表请求成功

if (httpRequest.readyState === 4 && httpRequest.status === 200) {

//获取响应数据

console.log(httpRequest.responseText);

}

if (httpRequest.readyState === 4 && httpRequest.status === 500) {

console.log('错误:' + httpRequest.responseText);

}

}

 

3. 编写代码完成数组内元素的反转

    答:

var arr = [8,19,3,12,5,4];
            Array.prototype.myfunction = function(){
                for(var i = 0;i<this.length/2;i++){
                    var temp = this[i];
                    this[i] = this[this.length-i-1];
                    this[this.length-i-1] = temp;
                }
                return this;
            }  
            console.log(arr.myfunction());

 

4. 使用你熟悉的排序算法完成数组的升序排列

  参数格式:

    var arr = [8,19,3,12,5,4];

  答:

    function test4(arr){

      // 冒泡排序

      for(var i=0;i<arr.length;i++){

        for(var j=0;j<arr.length-1;j++){

          if(arr[j]>arr[j+1]){

            // 交换位置

            var temp = arr[j];

            arr[j] = arr[j+1];

            arr[j+1] = temp;

          }

        }

      }

      console.log(arr);

    }

    test4(arr);

 

5. 现有DOM如下

    <ul>

      <li>first</li>

      <li>second</li>

      <li>third</li>

      <li>fourth</li>

      <li>fifth</li>

    </ul>

 

    为每个li使用原生DOM API绑定点击事件,要求点击first的时候弹出1,点击second的使用弹出2

 

    答:

      window.onload =  function(){

        //事件代理

        var ul = document.getElementsByTagName('ul')[0];

        ul.onclick = function(event){

          var li = event.target;

          if(li.nodeName=="LI"){

            if(li.innerText=="first"){

              alert(1);

            }else if(li.innerText=="second"){

              alert(2);

            }else{

              alert('其他');

            }

          }

        }

      }

 

 

上一篇:mysql从5.1.63升级到5.6.20出现的问题


下一篇:GreenDao 执行sql语句