1.javascript的typeof返回哪些数据类型
  Object number function boolean underfind

2.例举3种强制类型转换和2种隐式类型转换?
  强制(parseInt,parseFloat,number)
  隐式(== – ===)

3.split() join() 的区别
  前者是切割成数组的形式,后者是将数组转换成字符串

4.数组方法pop() push() unshift() shift()
  Push()尾部添加 pop()尾部删除
  Unshift()头部添加 shift()头部删除

5.事件绑定和普通事件有什么区别

  事件绑定就是针对dom元素的事件,绑定在dom元素上,普通事件即为非针对dom元素的事件、普通添加事件的方法不支持添加多个事件,最下面的事件会覆盖上面的,而事件绑定(addEventListener)方式添加事件可以添加多个。

  提示:addEventListener不兼容低版本IE,使用addEventListener添加事件之前,请先处理兼容问题。

普通添加事件的方法:

 var btn = document.getElementById("hello");
btn.onclick = function(){
alert(1);
}
btn.onclick = function(){
alert(2);
}

执行上面的代码只会alert 2

事件绑定方式添加事件:

 var btn = document.getElementById("hello");
btn.addEventListener("click",function(){
alert(1);
},false);
btn.addEventListener("click",function(){
alert(2);
},false);

执行上面的代码会先alert 1 再 alert 2

6.IE和DOM事件流的区别
  1.执行顺序不一样、
  2.参数不一样
  3.事件加不加on
  4.this指向问题

7.IE和标准下有哪些兼容性的写法
  Var ev = ev || window.event
  document.documentElement.clientWidth || document.body.clientWidth
  Var target = ev.srcElement||ev.target

8.ajax请求的时候get 和post方式的区别
  一个在url后面 一个放在虚拟载体里面
  有大小限制
  安全问题
  应用不同 一个是论坛等只需要请求的,一个是类似修改密码的

9.call和apply的区别
  Object.call(this,obj1,obj2,obj3)
  Object.apply(this,arguments)

10.ajax请求时,如何解释json数据
  使用eval parse 鉴于安全性考虑 使用parse更靠谱
  11.b继承a的方法

12.写一个获取非行间样式的函数

方法1:

function getStyle(obj, attr, value) {
if (!value) {
if (obj.currentStyle) {
return obj.currentStyle(attr)
}
else {
obj.getComputedStyle(attr, false)
}
}
else {
obj.style[attr] = value
}
}

方法2

function getStyle(obj, attr) {
return obj.currentStyle ? obj.currentStyle : getComputedStyle(obj)[attr];
}

13.事件委托是什么
  让利用事件冒泡的原理,让自己的所触发的事件,让他的父元素代替执行!
  
14.闭包是什么,有什么特性,对页面有什么影响
  闭包就是能够读取其他函数内部变量的函数。一个拥有许多变量和绑定了这些变量的环境的表达式(通常是一个函数),因而这些变量也是该表达式的一部分。闭包的特点:

  1. 作为一个函数变量的一个引用,当函数返回时,其处于激活状态。
  2. 一个闭包就是当一个函数返回时,一个没有释放资源的栈区。
  简单的说,Javascript允许使用内部函数---即函数定义和函数表达式位于另一个函数的函数体内。而且,这些内部函数可以访问它们所在的外部函数中声明的所有局部变量、参数和声明的其他内部函数。当其中一个这样的内部函数在包含它们的外部函数之外被调用时,就会形成闭包。
 (function(x, y){
alert(x + y);
})(2, 3);

15.如何阻止事件冒泡和默认事件
  canceBubble return false

16.添加 删除 替换 插入到某个接点的方法
  obj.appendChidl()
  obj.innersetBefore
  obj.replaceChild
  obj.removeChild

17.解释jsonp的原理,以及为什么不是真正的ajax
  动态创建script标签,回调函数
  Ajax是页面无刷新请求数据操作

18.javascript的本地对象,内置对象和宿主对象
  本地对象为array obj regexp等可以new实例化
  内置对象为gload Math 等不可以实例化的
  宿主为浏览器自带的document,window 等

19.document load 和document ready的区别
  Document.onload 是在结构和样式加载完才执行js
  Document.ready原生种没有这个方法,jquery中有 $().ready(function)

20.”==”和“===”的不同

  ”==”与”===”是不同的,一个是判断值是否相等,一个是判断值及类型是否完全相等。前者会自动转换类型,后者不会。

  先说 ===,这个比较简单。下面的规则用来判断两个值是否===相等: 
    1、如果类型不同,就[不相等] 
    2、如果两个都是数值,并且是同一个值,那么[相等];(!例外)的是,如果其中至少一个是NaN,那么[不相等]。(判断一个值是否是NaN,只能用isNaN()来判断) 
    3、如果两个都是字符串,每个位置的字符都一样,那么[相等];否则[不相等]。 
    4、如果两个值都是true,或者都是false,那么[相等]。 
    5、如果两个值都引用同一个对象或函数,那么[相等];否则[不相等]。 
    6、如果两个值都是null,或者都是undefined,那么[相等]。 
  再说 ==,根据以下规则: 
    1、如果两个值类型相同,进行 === 比较。 
    2、如果两个值类型不同,他们可能相等。根据下面规则进行类型转换再比较: 
    a、如果一个是null、一个是undefined,那么[相等]。 
    b、如果一个是字符串,一个是数值,把字符串转换成数值再进行比较。 
    c、如果任一值是 true,把它转换成 1 再比较;如果任一值是 false,把它转换成 0 再比较。 
    d、如果一个是对象,另一个是数值或字符串,把对象转换成基础类型的值再比较。对象转换成基础类型,利用它的toString或者valueOf方法。js核心内置类,会尝试valueOf先于toString;例外的是Date,Date利用的是toString转换。
    e、任何其他组合,都[不相等]。

  举例: 
    "1" == true 
    类型不等,true会先转换成数值 1,现在变成 "1" == 1,再把"1"转换成 1,比较 1 == 1, 相等。

  = 赋值运算符 
  == 等于 
  === 严格等于 
  例: 
    var a = 3; 
    var b = "3"; 
    a==b 返回 true 
    a===b 返回 false 
    因为a,b的类型不一样 
    ===用来进行严格的比较判断

简而言之就是“==”只要求值相等。“===”要求值和类型都相等。


21.javascript的同源策略
  一段脚本只能读取来自于同一来源的窗口和文档的属性,这里的同一来源指的是主机名、协议和端口号的组合

22.编写一个数组去重的方法

        window.onload = function () {
var arr = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 0, 1, 2, 3, 4, 5, 6, 7, 8, 9];
for (var i = 0; i < arr.length; i++) {
for (var j = i+1; j < arr.length; j++) {
if (arr[i] == arr[j]) {
arr.splice(j, 1);
j--;
}
}
}
alert(arr);
}

23.编写一个数组从大到小的排序方法

 //数组排序,从大到小,方法1:
var arrSimple=new Array(1,8,7,6);
arrSimple.sort();
document.write(arrSimple.join()); //数组排序,从大到小,方法2:
var arrSimple2=new Array(1,8,7,6);
arrSimple2.sort(function(a,b){
return b-a;
});
document.write(arrSimple2.join()); //解释:a,b表示数组中的任意两个元素,若return > 0 b前a后;reutrn < 0 a前b后;a=b时存在浏览器兼容简化一下:a-b输出从小到大排序,b-a输出从大到小排序。

24.如何交换两个数的位置

var a=10;
var b=20;
a= a+b;//
b= a-b;//
a= a-b;//
alert('a:'+a + 'b:'+b);

JavaScript经典面试题系列的更多相关文章

  1. JavaScript经典面试题(二)

    前言: 近年来T行业就业者越来越多,有关于编程行业的高薪工作也变得越来越难找,竞争力越来越大,想要在众多的应聘者当中脱颖而出,面试题和笔试题一定要多加研究和琢磨,以下记录的是自己的面试过程之中遇到的一 ...

  2. 20道JavaScript经典面试题

    该篇文章整理了一些前端经典面试题,附带详解,涉及到JavaScript多方面知识点,满满都是干货-建议收藏阅读 前言 如果这篇文章有帮助到你,️关注+点赞️鼓励一下作者,文章公众号首发,关注 前端南玖 ...

  3. javascript经典面试题之for循环click

    经典重现 <!DOCTYPE html> <html lang="en"> <head> <meta charset="utf- ...

  4. 前端必会的Javascript经典面试题

    这是前端最基础的问题,也是在面试中难倒无数同学的经典问题 01. Javascript 数据类型 Javascript 数据类型 = 基本类型 + 引用类型 ES6 之前 5 + 1 = 6 种 ES ...

  5. 前端javaScript经典面试题

    1.alert(1&&2),alert(1||0) alert(1&&2)的结果是2 只要“&&”前面是false,无论“&&”后面是t ...

  6. JavaScript经典作用域问题(转载)

    题目 var a = 10; function test(){ a = 100; console.log(a); console.log(this.a); var a; console.log(a); ...

  7. JavaScript之经典面试题

    1.作用域经典面试题 var num = 123; // f1函数写好了,作用域就定下来了,也就是作用域链定下来了 // f1函数作用域链: f1函数作用域 ==> 全局作用域 function ...

  8. net必问的面试题系列之基本概念和语法

    上个月离职了,这几天整理了一些常见的面试题,整理成一个系列给大家分享一下,机会是给有准备的人,面试造火箭,工作拧螺丝,不慌,共勉. 1.net必问的面试题系列之基本概念和语法 2.net必问的面试题系 ...

  9. .NET面试题系列[8] - 泛型

    “可变性是以一种类型安全的方式,将一个对象作为另一个对象来使用.“ - Jon Skeet .NET面试题系列目录 .NET面试题系列[1] - .NET框架基础知识(1) .NET面试题系列[2] ...

随机推荐

  1. 【Android - 基础】之Animator属性动画

    1      概述 在3.0系统之前,Android给我们提供了逐帧动画Frame Animation和补间动画Tween Animation两种动画: 1)        逐帧动画的原理很简单,就是 ...

  2. node.js在windows下的学习笔记(1)---安装node.js

    1.首先打开http://www.nodejs.org/ 2.选择DOWNLOADS,跳转到下面的画面,我的系统是windows7的32位.所以选择.msi的32bit版本. 3.下载后,得到一个5. ...

  3. 运行时动态修改webconfig

    网站运行时,如果直接手动修改webconfig.xml,会造成线程池重启,对于PV大的网站来说风险是很大的,并且如果有多台服务器,逐台修改也会造成数据不一致. .NET 2.0后可以通过代码修改web ...

  4. hdu4462 Scaring the Birds

    Scaring the Birds Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others ...

  5. Redis学习手册(String数据类型)

    一.概述: 字符串类型是Redis中最为基础的数据存储类型,它在Redis中是二进制安全的,这便意味着该类型可以接受任何格式的数据,如JPEG图像数据或Json对象描述信息等.在Redis中字符串类型 ...

  6. git 设置

    系统乱码 项目中的编码统一设置为UTF-8编码. 设置系统的语言设置为 zh_UTF-8,把 export LANG=zh_CN.UTF-8 保存到~/.profile文件里. $ env|grep ...

  7. python 2016 大会 pyconsk ppt ---python dtrace

    https://github.com/pyconsk/2016-slides PyCon SK 2016 - March 2016 1DTrace and PythonJesús Cea Aviónj ...

  8. web.xml配置文件 taglib

      web.xml的内容如下: <?xml version="1.0" encoding="UTF-8"?><web-app version= ...

  9. Java基础知识强化之IO流笔记55:IO流练习之 自定义类模拟LineNumberReader的获取行号功能案例

    1. 自定义类模拟LineNumberReader的获取行号功能案例 2. 代码实现: (1)MyBufferedReader.java: package cn.itcast_08; import j ...

  10. mac install php dev

    环境开发配置 mysql 下载mysql压缩包.tar.gz 解压 mv mysql_5.7.10_osx... /usr/local/mysql sudo chown -R root:wheel / ...