Javascript程序员常见面试题

2024-05-09 12:18

本文主要是介绍Javascript程序员常见面试题,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1.在Javascript中如何声明一个类?

在javascript中没有像Java中类class,我们调用一个函数实际上是在模拟类的行为。在JavaScript中有很多灵活的方法可以创建一个类,下面3种方式:

(1)使用函数作为类:


function Person(name) {
this.name = name;
}
// Creating an object
var person = new Person("Rafael");
person.name; // "Rafael"

这是非常重要的要注意,你必须使用关键字new创建一个类的新实例,否则将会有this是引用window对象这样的逻辑问题。

(2)类文字符号 Literal notation

var person = {
name: "",
setName: function(name) {
this.name = name;
}
}
person.setName("Rafael");
person.name; // "Rafael"

在这个例子中我们不能用函数来定义我们的类,我们创建一个单例对象Person,只有一个属性和一个方法,你可以直接使用这个对象,无需像上例中初始化。

当你无需参加类的多个实例或你只是使用一次,这种notation方式对你有用。

(3)通过函数实现的单例

var person = new function() {
this.setName = function(name) {
this.name = name;
}
this.sayHi = function() {
return "Hi, my name is " + this.name;
}
}
person.setName("Rafael");
alert(person.sayHi()); // Hi, my name is Rafael

这里在函数function前面我们加了一个new关键字,这意味着我们在申明它之时同时创建了这个类的一个实例。

2.如何组织你的Javascript代码?

“模块模式”可以将我们javascript划分成多个逻辑模块命名空间:

// Declaring my main namespace定义主命名空间

var myapplication = myapplication || {};

 

// Declaring modules usermodule 定义模块usermodule

myapplication.usermodule = (function() {

    // createMessage: only accessible inside this module

    var createMessage = function(message) {

        return "Hello! " + message;

    }

 

    return {

        // sayHello is a public method

        sayHello: function(message) {

            return createMessage(message);

        }

    }

})();

 

// Declaring another module 定义另外一个模块

myapplication.adminmodule = (function(){

    // your code here

})()

// This is how we call sayHello

myapplication.usermodule.sayHello("This is my module");

注意上面代码中是如何使用notation创建模块usermodule的,

...

myapplication.usermodule = (function() {

    // code to be executed immediately

})();

这能够使得函数立即执行,因为在这个命令尾部有插入语,这个执行的结果将是一个对象,赋值给变量myapplication.usermodule。

使用这个模式,你可以有多个模块,你能够控制那些是公开public,哪些是保持私有private,这样你的代码组织得更易于维护。

3. ==和===的区别?

两个等于号==是用来比较两个操作数的值:

"2" == 2; //true

2 == 2; // true

三重等于号===是用来比较两个操作符类型的AND值

"2" === 2; //false

2 === 2; // true

4. null和undefined的区别是什么?

null是代表一个对象没有值,而undefned是一种类型。

typeof null; // "object"

typeof undefined; // "undefined"

var a;

var b = null;

a == b; // "true" because their values are the same

a === b; // "false". they have different types

5.你以前使用过MVC吗?你喜欢或不喜欢它的哪些方面?

由于用户界面变得越来越复杂,我们需要一些好的方法来保持它越来越多的可维护性和重用性,如今一些JavaScript的MVC框架已被广泛采用,最著名的MVC框架是 backbone.js 和 angular.js

使用这些框架的优点是:

  • 组织架构: 能够强迫你的web应用服从一个好的架构模式;
  • 可维护性: 因为好的架构组织性带来了易于维护性;
  • UI绑定性: 一些框架允许你这样做,当每次你的模型改变时,视图将自动映射改变。
  • 解耦客户端: 类似 backbone.js这样的MVC框架能激励你使用REST API,通过他们模型中的urlRoot属性;
  • 可重用的组件: 能够创建可重用的可视化组件
  • 单页应用Single-page apps: 能够使用Ajax 请求构建单页应用;
  • URL友好型: 原生支持客户端url映射

6. 如何增加一个方法到一个已经定义的类中?

使用prototype可以实现:

function Person(name) {

    this.name = name;

}

Person.prototype.walk = function() {

    console.debug(this.name + " is walking.");

}

// Calling the new method

var person = new Person("Rafael");

person.walk(); // "Rafael is walking."

值得注意的是,通过原型prototypr增加方法在性能上也是廉价的,因为这个方法被绑定到类的prototype上,对于类Person每一个新实例,你都能访问prototype的walk()方法,如果你在Person类中定义walk()方法,你最终会重新创建方法,为Person每一个新的实例。

这篇关于Javascript程序员常见面试题的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/973391

相关文章

java设计模式之工厂模式--普通工厂方法模式(Factory Method)

1.普通工厂模式,就是建立一个工厂类,对实现了同一接口的一些类进行实例的创建。 2.先定义一个接口: package com.zhong.pattern.factorymethod;/*** 发送接口* @author admin**/public interface Sender {/*** 发送消息方法* @param msg*/void send(String msg);} 3

Java设计模式之代理模式2-动态代理(jdk实现)

这篇是接着上一篇继续介绍java设计模式之代理模式。下面讲解的是jdk实现动态代理。 1.)首先我们要声明一个动态代理类,实现InvocationHandler接口 package com.zhong.pattern.proxy;import java.lang.reflect.InvocationHandler;import java.lang.reflect.Method;/*** 演

java设计模式之代理模式1--静态代理

Java编程的目标是实现现实不能完成的,优化现实能够完成的,是一种虚拟技术。生活中的方方面面都可以虚拟到代码中。代理模式所讲的就是现实生活中的这么一个概念:助手。 代理模式的定义:给某一个对象提供一个代理,并由代理对象控制对原对象的引用。 1.)首先新建一个表演的接口 package com.zhong.pattern.proxy;/*** 表演接口* @author admin*

java原型(Prototype)设计模式

原型模式就是讲一个对象作为原型,使用clone()方法来创建新的实例。 public class Prototype implements Cloneable{private String name;public String getName() {return name;}public void setName(String name) {this.name = name;}@Overri

Java中23种设计模式之适配者模式

适配器模式的作用就是在原来的类上提供新功能。 主要可分为3种: 1.类适配:创建新类,继承源类,并实现新接口,例如:     class Adapter extends OldClass implements NewFunc{} 2.对象适配:创建新类持源类的实例,并实现新接口,例如:     class Adapter implements NewFunc { priva

java不依赖临时变量交换两个变量的值

java不依赖临时变量交换两个变量的值 1.简单易懂的实现方式     int a=1,b=2;     int temp = 0;     temp = a;     a = b;     b= temp; 2.算术算法 int a=1,b=2; a = a+b;// a = 1+2  b = a-b;// b = a-b --> b=3-2 -->1 a = a -b;/

Java中的SOLID原则及示例

类是任何Java应用程序的构建块。如果这些区块不强,那么建筑(即应用)将来将面临艰难时期。这实际上意味着,当应用程序范围上升或应用程序在生产或维护中面临某些设计问题时,不那么好的编写会导致非常困难的情况。 另一方面,一组精心设计和编写的类可以加速编码过程的突飞猛进,同时减少错误的数量。 在本教程中,我们将使用 5个最推荐的设计原则的示例来讨论Java中的SOLID原则,在编写类时我们应该记住这

Java比较和交换示例 - CAS算法

Java比较和交换示例 - CAS算法 由Lokesh Gupta | 提起下:多线程 一个Java 5中最好添加的是支持类,如原子操作AtomicInteger,AtomicLong等等。这些课程帮助您最大限度地减少复杂的(非必要)需要多线程的,如增加一些基本的操作代码或递减的值在多个线程之间共享。这些类内部依赖于名为CAS(比较和交换)的算法。在本文中,我将详细讨论这个概念。 1.乐观和

java并发编程之CyclicBarrier(循环栅栏)

package com.zhong;import java.util.concurrent.CyclicBarrier;/*** Cyclic意思是循环,Barrier意思是屏障,那么CyclicBarrier翻译过来就是循环栅栏。* 它是一个同步辅助类,能让一组线程互相等待,* 直到这一组线程都到了一个公共屏障点,各线程才能继续向下执行。因为该屏障能够在释放等待线程后继续重用,所以叫循环屏障。*

Java内存管理 - 垃圾收集算法

我们都知道Java 中垃圾收集器 [GC] 的功能。但只有少数人试图深入了解垃圾收集的工作原理。你不是其中之一,这就是你在这里的原因。 在这个Java内存管理教程中,我们将尝试了解Java垃圾收集的当前算法,我们将了解这些算法的演变。 目录1. Java中的内存管理2.引用计数机制3.标记和清除机制4.停止并复制GC 5.分代停止和复制6.如何提高Java中的内存利用率 1.