Javascript常见问题

js的基本数据类型

  Undefined、Null、Boolean、Number、String

js有哪些内置对象?

  Object 是 JavaScript 中所有对象的父对象

  数据封装类对象:Object、Array、Boolean、Number 和 String

  其他对象:Function、Arguments、Math、Date、RegExp、Error

JavaScript的基本规范?

  不要在同一行声明多个变量

  使用 ===/!==来比较true/false或者数值

  使用对象字面量替代new Array这种形式

  不要使用全局函数

  Switch语句必须带有default分支

  函数不应该有时候有返回值,有时候没有返回值。

  For循环必须使用大括号

  If语句必须使用大括号

  for-in循环中的变量 应该使用var关键字明确限定作用域,从而避免作用域污染。

JavaScript原型,原型链?有什么特点?

  每个对象都会在其内部初始化一个属性,就是prototype(原型),当我们访问一个对象的属性时, 如果这个对象内部不存在这个属性,那么他就会去prototype里找这个属性,

  这个prototype又会有自己的prototype, 于是就这样一直找下去,也就是我们平时所说的原型链的概念。

  关系:instance.constructor.prototype = instance.__proto__

  特点: JavaScript对象是通过引用来传递的,我们创建的每个新对象实体中并没有一份属于自己的原型副本。当我们修改原型时,与之相关的对象也会继承这一改变。

  当我们需要一个属性的时,Javascript引擎会先看当前对象中是否有这个属性, 如果没有的话, 就会查找他的Prototype对象是否有这个属性,如此递推下去,一直检索到 Object 内建对象。

  function Func(){}

  Func.prototype.name = "Sean";

  Func.prototype.getInfo = function(){  return this.name;  }

  var person = new Func();//现在可以参考var person = Object.create(oldObject);

  console.log(person.getInfo());//它拥有了Func的属性和方法 //"Sean"

  console.log(Func.prototype);

JavaScript有几种类型的值?,你能画一下他们的内存图吗?

  栈:原始数据类型(Undefined,Null,Boolean,Number、String)

  堆:引用数据类型(对象、数组和函数)

  两种类型的区别是:存储位置不同;

  原始数据类型直接存储在栈(stack)中的简单数据段,占据空间小、大小固定,属于被频繁使用数据,所以放入栈中存储;

  引用数据类型存储在堆(heap)中的对象,占据空间大、大小不固定,如果存储在栈中,将会影响程序运行的性能;引用数据类型在栈中存储了指针,

  该指针指向堆中该实体的起始地址。当解释器寻找引用值时,会首先检索其 在栈中的地址,取得地址后从堆中获得实体

Javascript如何实现继承?

  构造继承

  原型继承

  实例继承

  拷贝继承

  原型prototype机制或apply和call方法去实现较简单,建议使用构造函数与原型混合方式。

  function Parent(){  this.name = 'wang';   }

  function Child(){  this.age = 28;   }

  Child.prototype = new Parent();//继承了Parent,通过原型

  var demo = new Child();

  alert(demo.age);

  alert(demo.name);//得到被继承的属性

JavaScript继承的几种实现方式?

  构造函数的继承

    function Animal(){  this.species = "动物";  }

    function Cat(name,color){  this.name = name;this.color = color;  }

    Cat.prototype = new Animal();

    Cat.prototype.constructor = Cat;

    var cat1 = new Cat("大毛","黄色");

    alert(cat1.species); // 动物

  非构造函数的继承;

    var Chinese = {nation:'中国'};

    var Doctor ={career:'医生'}

    function object(o) {function F() {}F.prototype = o;return new F();}

    var Doctor = object(Chinese);

    Doctor.career = '医生';

    alert(Doctor.nation); //中国

javascript创建对象的几种方式?

  javascript创建对象简单的说,无非就是使用内置对象或各种自定义对象,当然还可以用JSON;但写法有很多种,也能混合使用。

  对象字面量的方式

    person={firstname:"Mark",lastname:"Yun",age:25,eyecolor:"black"};

  用function来模拟无参的构造函数

    function Person(){}

    var person=new Person();//定义一个function,如果使用new"实例化",该function可以看作是一个Class

    person.name="Mark";

    person.age="25";

    person.work=function(){ alert(person.name+" hello..."); }

    person.work();

  用function来模拟参构造函数来实现(用this关键字定义构造的上下文属性)

    function Pet(name,age,hobby){ this.name=name;//this作用域:当前对象 this.age=age; this.hobby=hobby; this.eat=function(){ alert("我叫"+this.name+",我喜欢"+this.hobby+",是个程序员"); } }

    var maidou =new Pet("麦兜",25,"coding");//实例化、创建对象

    maidou.eat();//调用eat方法

  用工厂方式来创建(内置对象)

    var wcDog =new Object();

    wcDog.name="旺财";

    wcDog.age=3;

    wcDog.work=function(){ alert("我是"+wcDog.name+",汪汪汪......"); }

    wcDog.work();

  用原型方式来创建

    function Dog(){ }

    Dog.prototype.name="旺财";

    Dog.prototype.eat=function(){ alert(this.name+"是个吃货"); }

    var wangcai =new Dog();

    wangcai.eat();

  用混合方式来创建

    function Car(name,price){ this.name=name; this.price=price; }

    Car.prototype.sell=function(){ alert("我是"+this.name+",我现在卖"+this.price+"万元"); }

    var camry =new Car("凯美瑞",27);

    camry.sell();

Javascript作用链域?

  全局函数无法查看局部函数的内部细节,但局部函数可以查看其上层的函数细节,直至全局细节。

  当需要从局部函数查找某一属性或方法时,如果当前作用域没有找到,就会上溯到上层作用域查找, 直至全局函数,这种组织形式就是作用域链。

谈谈This对象的理解

  this总是指向函数的直接调用者(而非间接调用者);

  如果有new关键字,this指向new出来的那个对象;

  在事件中,this指向触发这个事件的对象,特殊的是,IE中的attachEvent中的this总是指向全局对象Window;

eval是做什么的?

  它的功能是把对应的字符串解析成JS代码并运行;

  应该避免使用eval,不安全,非常耗性能(2次,一次解析成js语句,一次执行)。

  由JSON字符串转换为JSON对象的时候可以用eval,var obj =eval('('+ str +')');

什么是闭包(closure),为什么要用它?

  闭包是指有权访问另一个函数作用域中变量的函数,创建闭包的最常见的方式就是在一个函数内创建另一个函数,

  通过另一个函数访问这个函数的局部变量,利用闭包可以突破作用链域,将函数内部的变量和方法传递到外部。

  闭包的特性:

    函数内再嵌套函数

    内部函数可以引用外层的参数和变量

    参数和变量不会被垃圾回收机制回收

javascript 代码中的"use strict";是什么意思 ? 使用它区别是什么

  use strict是一种ECMAscript 5 添加的(严格)运行模式,这种模式使得 Javascript 在更严格的条件下运行。

  使JS编码更加规范化的模式,消除Javascript语法的一些不合理、不严谨之处,减少一些怪异行为。 默认支持的糟糕特性都会被禁用,比如不能用with,也不能在意外的情况下给全局变量赋值;

  全局变量的显示声明,函数必须声明在顶层,不允许在非函数代码块内声明函数,arguments.callee也不允许使用; 消除代码运行的一些不安全之处,保证代码运行的安全,限制函数中的arguments修改,

  严格模式下的eval函数的行为和非严格模式的也不相同;

  提高编译器效率,增加运行速度; 为未来新版本的Javascript标准化做铺垫。

如何判断一个对象是否属于某个类?

  if(a instanceof Person){ alert('yes'); }

new操作符具体干了什么呢?

  创建一个空对象,并且 this 变量引用该对象,同时还继承了该函数的原型。

  属性和方法被加入到 this 引用的对象中。

  新创建的对象由 this 所引用,并且最后隐式的返回 this 。

  var obj = {};

  obj.__proto__ = Base.prototype;

  Base.call(obj);

Javascript中,有一个函数,执行时对象查找时,永远不会去查找原型,这个函数是?

  hasOwnProperty

  javaScript中hasOwnProperty函数方法是返回一个布尔值,指出一个对象是否具有指定名称的属性。此方法无法检查该对象的原型链中是否具有该属性;该属性必须是对象本身的一个成员。 使用方法:

  object.hasOwnProperty(proName)

  其中参数object是必选项。一个对象的实例。

  proName是必选项。一个属性名称的字符串值。

  如果 object 具有指定名称的属性,那么JavaScript中hasOwnProperty函数方法返回 true,反之则返回 false。

JSON 的了解?

  JSON(JavaScript Object Notation) 是一种轻量级的数据交换格式。

  它是基于JavaScript的一个子集。数据格式简单, 易于读写, 占用带宽小 如:{"age":"12", "name":"back"}

  JSON字符串转换为JSON对象:

  var obj =eval('('+ str +')');

  var obj = str.parseJSON();

  var obj = JSON.parse(str);

  JSON对象转换为JSON字符串:

Ajax 是什么? 如何创建一个Ajax?

  ajax的全称:Asynchronous Javascript And XML。

  异步传输+js+xml。

  所谓异步,在这里简单地解释就是:向服务器发送请求的时候,我们不必等待结果,而是可以同时做其他的事情,等到有了结果它自己会根据设定进行后续操作,

  与此同时,页面是不会发生整页刷新的,提高了用 户体验。

  创建XMLHttpRequest对象,也就是创建一个异步调用对象

  创建一个新的HTTP请求,并指定该HTTP请求的方法、URL及验证信息

  设置响应HTTP请求状态变化的函数

  发送HTTP请求

  获取异步调用返回的数据

  使用JavaScript和DOM实现局部刷新

如何解决跨域问题?

  jsonp、 iframe、window.name、window.postMessage、服务器上设置代理页面

AMD(Modules/Asynchronous-Definition)、CMD(Common Module Definition)规范区别?

  //CMD

    define(function(require, exports, module) { var a = require('./a') a.doSomething() // 此处略去 100 行 var b = require('./b') // 依赖可以就近书写 b.doSomething() // ... })

  //AMD 默认推荐

    define(['./a', './b'], function(a, b) { // 依赖必须一开始就写好 a.doSomething() // 此处略去 100 行 b.doSomething() // ... })

异步加载JS的方式有哪些?

  defer,只支持IE

  async:

  创建script,插入到DOM中,加载完毕后callBack

documen.write和 innerHTML的区别?

  document.write只能重绘整个页面

  innerHTML可以重绘页面的一部分

DOM操作——怎样添加、移除、移动、复制、创建和查找节点?

  创建新节点

    createDocumentFragment() //创建一个DOM片段

    createElement() //创建一个具体的元素

    createTextNode() //创建一个文本节点

  添加、移除、替换、插入

    appendChild()

    removeChild()

    replaceChild()

    insertBefore() //在已有的子节点前插入一个新的子节点

   查找

    getElementsByTagName() //通过标签名称

    getElementsByName() //通过元素的Name属性的值(IE容错能力较强,会得到一个数组,其中包括id等于name值的)

    getElementById() //通过元素Id,唯一性

WEB应用从服务器主动推送Data到客户端有那些方式?

  html5提供的Websocket

  不可见的iframe

  WebSocket通过Flash

  XHR长时间连接

  XHR Multipart Streaming

posted @ 2016-07-14 13:51  ccsaber  阅读(107)  评论(0)    收藏  举报