1. class的概念

定义一个class,属性都是private,方法都是public。

Hello.js:

使用class

index.js:

2. 单例类

使用exports而不是module.exports。区别在于Hello导出的是新的Function对象,而single导出的是single.js的初始对象{}。

属性都是private,方法都是public需要exports接口导出。

exports.name = name,相当于给接口{}创建动态属性。是无法导出var name的,因为name不是引用类型。

single.js:

new single()的话会报错。无论在哪里引用require single,值getName都是一样的。

index.js:

3. JS方法和变量的总结

1 对象的方法和属性。可理解为对象原本包含的变量和方法。

Hello.js

//模块封装Hello类
module.exports = Hello; //Hello类定义
function Hello(){
this.age = 1; this.setAge = function(age){
this.age = age;
} this.getAge = function (){
return this.age;
}
}

  

index.js

var Hello = require("./Hello.js");
var hello = new Hello(); //访问age
console.log(hello.age); //1
console.log(hello.getAge()); //1 //修改age
hello.setAge(2); //访问修改后的age
console.log(hello.age); //2
console.log(hello.getAge()); //2 //新的实例,age初始值不变
var hello2 = new Hello();
console.log(hello2.age); //1

  

  

 2 类方法和变量,可理解为类的静态变量和方法

Hello.js

//模块封装Hello类
module.exports = Hello; //Hello类定义
function Hello(){ } Hello.age = 1; Hello.getAge = function(){
return Hello.age;
}

 index.js

var Hello = require("./Hello.js");
var hello = new Hello(); //实例无法访问静态变量
console.log(hello.age); //undifined
//console.log(hello.getAge()); //报错 //访问age
console.log(Hello.age); //1
console.log(Hello.getAge()); //1 //修改age
Hello.age = 2; //访问修改后age
console.log(Hello.age); //2
console.log(Hello.getAge()); //2

 3 原型变量和方法,可理解为对象原本包含的变量和方法。可用于继承。

Hello.js

//模块封装Hello类
module.exports = Hello; //Hello类定义
function Hello(){ } Hello.prototype.age = 1; Hello.prototype.getAge = function(){
return Hello.prototype.age;
}

index.js

var Hello = require("./Hello.js");
var hello = new Hello(); //访问age
console.log(hello.age); //1
console.log(hello.getAge()); //1 //修改age
hello.age = 2; //访问修改后的age
console.log(hello.age); //2
console.log(hello.getAge()); //1 //新的实例
var hello2 = new Hello();
console.log(hello.age); //2
console.log(hello.getAge()); //1

  

4  类外的变量和方法 

Hello.js

//模块封装Hello类
module.exports = Hello; var age = 1;
var getAge2 = function(){
return age;
} //Hello类定义
function Hello(){ this.setAge = function(_age){
age = _age;
} this.getAge = function (){
return age;
}
}

index.js

var Hello = require("./Hello.js");
var hello = new Hello(); //访问age
console.log(hello.age); //undifined
console.log(hello.getAge()); //1 //无法访问getAge2()
//console.log(hello.getAge2()); //报错
//Hello.getAge2(); //报错 //修改age
hello.setAge(2); //访问修改后的age
console.log(hello.age); //undifined
console.log(hello.getAge()); //2 //新的实例
var hello2 = new Hello();
console.log(hello2.age); //undifined
console.log(hello2.getAge()); //2

  

总结:

1. 无法和java、c#那样有class extends implements private protected public static等来定义变量和方法。

2. 对于非前端js的使用者,nodejs的对象使用很变扭。

node中的对象的更多相关文章

  1. node中非常重要的process对象,Child Process模块

    node中非常重要的process对象,Child Process模块Child Process模块http://javascript.ruanyifeng.com/nodejs/child-proc ...

  2. node中的Stream-Readable和Writeable解读

    在node中,只要涉及到文件IO的场景一般都会涉及到一个类-Stream.Stream是对IO设备的抽象表示,其在JAVA中也有涉及,主要体现在四个类-InputStream.Reader.Outpu ...

  3. 深入理解jQuery、Angular、node中的Promise

    最初遇到Promise是在jQuery中,在jQuery1.5版本中引入了Deferred Object,这个异步队列模块用于实现异步任务和回调函数的解耦.为ajax模块.队列模块.ready事件提供 ...

  4. Node中的定时器详解

    在大多数的业务中,我们都会有一些需求,例如几秒钟实现网页的跳转,几分钟对于后台数据进行清理,node与javascript都具有将代码延迟一段时间的能力.在node中可以使用三种方式实现定时功能:超时 ...

  5. node中的流程控制中,co,thunkify为什么return callback()可以做到流程控制?

    前言 我在学习generator ,yield ,co,thunkify的时候,有许多费解的地方,经过了许多的实践,也慢慢学会用,慢慢的理解,前一阵子有个其他项目的同事过来我们项目组学习node,发现 ...

  6. c++中返回对象与返回引用的区别

    这几天在做用C++做课程设计,对其返回对象的实现感到迷惑. 通过对汇编代码的分析,可以清楚的看到,直接返回引用和返回对象的区别到底是什么. 分析的程序如下 #include<cstdio> ...

  7. Node.js全局对象

    Node.js的全局对象是具有全局性的,它们可在所有的模块中应用.我们并不需要包括这些对象在应用中,而可以直接使用它们.这些对象的模块,函数,字符串和对象本身,如下所述. __filename __f ...

  8. 使用express+multer实现node中的图片上传

    使用express+multer实现node中的图片上传 在前端中,我们使用ajax来异步上传图片,使用file-input来上传图片,使用formdata对象来处理图片数据,post到服务器中 在n ...

  9. 简单剖析Node中的事件监听机制(一)

    使用js的class类简单的实现一个事件监听机制,不同于浏览器中的时间绑定与监听,类似于node中的时间监听,并且会在接下来的文章中去根据自己的理解去写一下Event模块中的原理. Node.js使用 ...

随机推荐

  1. WPF路由事件一:逻辑树和可视树

    一.什么是逻辑树 逻辑树就是描述WPF界面元素的实际构成,它是由程序在XAML中所有的UI元素组成.最显著的特点就是由布局控件.或者其他常用的控件组成. <Window x:Class=&quo ...

  2. thinkphp 自动跟新时间

    看了很多文章和资料了,明白何为真传一句话了... 模板里: <input type="text" name="time" value="{:da ...

  3. 1077. Kuchiguse (20)【字符串处理】——PAT (Advanced Level) Practise

    题目信息 1077. Kuchiguse (20) 时间限制100 ms 内存限制65536 kB 代码长度限制16000 B The Japanese language is notorious f ...

  4. Swift数值运算

    Swift 让全部数值类型都支持了主要的四则运算: 加法(+) 减法(-) 乘法(*) 除法(/) 1 + 2 // 等于 3 5 - 3 // 等于 2 2 * 3 // 等于 6 10.0 / 2 ...

  5. Linux基础知识之history的详细说明

    背景:history是Linux中常会用到内容,在工作中一些用户会突然发现其安装不了某个软件,于是寻求运维人员的帮助,而不给你说明他到底做了哪些坑爹的操作.此时你第一件要做的就是要查看其history ...

  6. 【java 类加载的深入研究1】loadClass()的研究

    1.开门见山 以前曾经看到过一个java的面试题,当时觉得此题很简单,可是自己把代码运行起来,可是结果并不是自己想象的那样.题目如下: class SingleTon { private static ...

  7. jquery-file-upload附件上传

    引入样式和js文件 <link href="css/bootstrap.min.css" type="text/css" rel="styles ...

  8. Shell 启动java程序

    #!/bin/sh SHELL_PATH=$(cd ")";pwd) echo $SHELL_PATH cd "$SHELL_PATH" CLASSPATH=. ...

  9. Linux下的CPU性能瓶颈分析案例

    问题描述: 在对notify执行性能测试时发现cpu负载突然飙高,cpu利用率高达95%.这时候就要排查是哪些线程消耗了cpu,并从代码层找到占用cpu的“罪魁祸首”. 步骤: 1. 先用ps+gre ...

  10. 基于Nginx反向代理及负载均衡

    基于Nginx反向代理及负载均衡 参考:http://nginx.org/en/docs/http/ngx_http_proxy_module.html#proxy_pass 只要没有被启用,默认就是 ...