Node.js和JavaScript:

核心都是ECMAScrit,比如数据类型,语法结构,内置对象等等。

但是在js中顶层是window

在node中的不存在这个window(console.log(this)的结果是{}),它的顶层是全局对象(global),但是,当在node.js中定义一个a时。通过却global.a访问不了a。

javascript

包括ECMAScript、DOM和BOM

而node.js包括

ECMAScript、OS(操作系统)、file(文件)、net(网络)和database(数据库)。

前者用于运行浏览器,后者用来操作系统。

简单的说 Node.js 就是运行在服务端的 JavaScript。

  • Node.js 是一个基于Chrome JavaScript 运行时建立的一个平台。

  • Node.js是一个事件驱动I/O服务端JavaScript环境,基于Google的V8引擎,V8引擎执行Javascript的速度非常快,性能非常好。


第一段node.js程序

新建一个hello.js文件

  1. console.log('hello nod.js!');

去官网下载编译器安装包。安装完之后双击出现命令行

也可以通过win+R打开cmd,输入node回车



表示安装没问题。退出:Ctrl+D或者Ctrl+C两次。

看版本(没有进入node.js时候):node -v



现在允许之前的hello.js文件,node 路径文件名即可、



路径比较麻烦的话,可以如下操作



这样就可以通过相对路径进行访问

webstorm环境下使用node.js

以下通过webstorm来操作node.js

打开一个空文件夹以创建项目

在settings里面添加



加载node.js的npm

点确定。就可以右键run运行node.js了。

模块的使用

var a=100

这个a是属于模块的,不是全局变量。一个文件就是一个模块。每个模块都有自己的作用域。

我们使用var 声明的一个变量,他并不就是全局的,而是属于当前模块。

你想声明一个全局变量,必须global.a=200

每个文件都有一个独特的__filename属性

  1. //__filename:当前文件被解析之后的绝对路径(双下划线)
  2. console.log(__filename);

模块加载

在javascript的书写方法下引入其它js是通过<script>而在当前,用的是:

在1.js的同一个目录下新建一个2.js

写入

  1. console.log('这是模块2.js')

保存

然后回到1.js输入reruire('./2.js')

ctrl+shift+F10.发现模块2.js的内容被打印出来了。

模块的加载机制

require('模块路径')

  • 模块路径问题:可以写相对,也可以写绝对。相对路径同目录下必须加上../如果直接写,加载的是node.js中的核心模块。或者是node_modules
  • 你可以写require(../2),可以查找到,首先按照模块文件名称进行经查找。如果没有找到,会在模块名称后加上.js后缀进行查找。
  • 如果还未查找到,则会查找.json后缀
  • 再找不到就是查找.node后缀,还没有的话再弹出错误。

module和exports

如何调用其它模块内的变量?

在2.js中写入var a=100,在1.js中想要用到2.js中的a,不能在require 2.js后,直接console.log(a)!!——然而你可以:

如果模块能够访问另一个模块中的变量。可以:

  • 把变量作为global对象属性(global.a=100)——不推荐此做法。(全局污染)
  • 使用模块接口: module——保存和当前模块有关的信息。module下有一个子对象:exports对象。可以通过它把一个模块的局部变量输出到别的模块中。

    在2.js文件写入:
  1. var a=100;
  2. module.exports.a=a;

而1.js这样写:

  1. var m=require('./2');//返回值其实就是被加载模块中的module.exports
  2. console.log(m);

返回的是{a:100}.也就是说,require('./2')返回的是所有在模块2中被定义的值的集合。在模块作用域,还有内置的模块对象exports——其实就是module.exports

  1. var a=100;
  2. module.exports.a=a;
  3. console.log(module.exports===exports)//返回true

注意不要破坏引用关系,如果2.js这样写:

  1. var a=100;
  2. module.exports.a=a;
  3. module.exports=[1,2,3];

1.js引入2.js后,就找不到a了。

Node.js入门笔记(1):基本概念的更多相关文章

  1. Node.js入门笔记(6):web开发方法

    使用node进行web开发 用户上网流程: 表面上看:打开浏览器--输入网址--跳转--上网. 背后的过程是什么呢? http请求网址到指定的主机--服务器接收请求--服务器响应内容到用户浏览器--浏 ...

  2. Node.js入门笔记(5):案例两则

    案例分析:前端自动化 1. 实现一个自动创建前端项目文件的js 通过node.js自动创建前端项目目录,包括js目录,js目录css目录,index.html和对应的内容. 初步的代码如下: var ...

  3. Node.js入门笔记

    第一步自然是安装了.我是用Webstorm这个ide,安装分2步: 1.安装nodejs,下载Windows下的安装版本号.注意是以msi为扩展名的,然后下一步.没啥好说的,下载地址例如以下: 32位 ...

  4. Node.js入门笔记(2):全局对象(1)

    以下将以API文档为基础进行分析学习 global对象 这些对象在所有模块里都可用.有些对象不是在全局作用域而是在模块作用域里,这些情况下面文档都会标注出来. __filename--返回当前模块文件 ...

  5. Node.js入门笔记(4):文件系统(fs)

    文件系统(FileSystem) 文件系统模块 对于文件无外乎创建修改添加. File System - 文件系统模块 - require('fs') fs模块是核心模块,需要使用require导入后 ...

  6. Node.js入门笔记(3):全局对象(2)

    buffer 用于更好操作二进制数据,他是一个全局变量.类似数组. var a=new Buffer(); buffer类的三种实现 第一种创建方式 new Buffer(size);size[Num ...

  7. Node.js 入门资料

    小毛驴的阿凡提的 Node.js 入门笔记 http://www.cnblogs.com/Afanty/category/1007304.html

  8. 《Node.js入门》CentOS 6.5下Node.js Web开发环境搭建笔记

    近期想尝试一下英特尔的基于WebRTC协同通信开发套件,所以须要在本地搭建Node.js Web的开发測试环境. 这里讲的是CentOS 下的搭建方法.使用Windows的小伙伴请參考: <No ...

  9. React.js入门笔记

    # React.js入门笔记 核心提示 这是本人学习react.js的第一篇入门笔记,估计也会是该系列涵盖内容最多的笔记,主要内容来自英文官方文档的快速上手部分和阮一峰博客教程.当然,还有我自己尝试的 ...

随机推荐

  1. 分布式搜索引擎Elasticsearch的查询与过滤

    一.写入 先来一个简单的官方例子,插入的参数为-XPUT,插入一条记录. curl -XPUT 'http://localhost:9200/test/users/1' -d '{ "use ...

  2. java 版本EChart使用

    一.简介 EChart是百度开发的js图表软件,用它我们可以很方便地以图形化的方式对数据进行分析统计.该种方式js在页面动态拼接json数据,再进行渲染.这种方法的优点是,灵活,可以随时进行修改.缺点 ...

  3. 常用ADC滤波处理

    #define N 70 XDATA WORD Value_buf[N]; XDATA DWORD ADCValue; static BYTE v_gu8cnt=0; static BYTE i=0; ...

  4. PXC(Percona XtraDB Cluster)集群的安装与配置

    Percona XtraDB Cluster是针对MySQL用户的高可用性和扩展性解决方案,基于Percona Server .其包括了Write Set REPlication补丁,使用Galera ...

  5. DOM document object model learn

    DOM对W3C DOM而言,HTML文档中任何一样东西都是一个节点,而且节点之间是有层次的.如<p>I am a JavaScript hacker.</p>有两个节点,一个是 ...

  6. 【WPF系列】Textbox

    Style定义实例 给Textbox定义一个阴影效果. <Style x:Key="{x:Type TextBox}" TargetType="{x:Type Te ...

  7. 一切Web的基础----HTTP

    HTTP 是基于 TCP/IP 协议的应用层协议.它不涉及数据包(packet)传输,主要规定了客户端和服务器之间的通信格式,默认使用80端口.HTTP协议基于TCP连接,该协议针对TCP连接上的数据 ...

  8. LCA 倍增||树链剖分

    方法1:倍增 1498ms #include <iostream> #include <cstdio> #include <algorithm> #include ...

  9. Apache Shiro系列之五,概述 —— 配置

    Shiro设计的初衷就是可以运行于任何环境:无论是简单的命令行应用程序还是复杂的企业集群应用.由于运行环境的多样性,所以有多种配置机制可用于配置,本节我们将介绍Shiro内核支持的这几种配置机制.   ...

  10. Multiple Contexts have a path of 错误

    1.问题描述 在eclipse里面启动tomcat的时候,看到报错,multiple contexts have a path.tomcat启动失败 2.解决办法 删除tomcat,重新加载部署tom ...