为什么我们要学习Node.js?

  1. 认为:

    • Node.js就学习一周,时间比较短,不重要
    • 将来工作我后端又不用Node.js做,我们又java/python/php/c,为什么要在意它
    • Node.js接下来项目中又不用,不用好好学,不用在意
  2. 重要性?

    • Node.js可以说是对js功能的扩展,比如: Node.js可以操作文件,数据库
    • Node.js是webpack的底层语言,如果Node.js不了解,那么我们webpack学不好
    • Node.js是现在vue/React中构建项目的一环,如果学不好,那么会导致Vue/React基础不好
    • Node.js可以充当前后端连接的一个桥梁
    • Node.js也可以当做后端这个角色来看,如果我们想和后端配合的更好,那么我们必须了解后端,Node.js可以说是我们接触后端的一个方式
    • Node.js现在已经成为很多企业的职位要求了
  3. Node.js 是一个基于Chrome V8 引擎的JavaScript运行环境

    • 服务端的js有什么能力?(服务器)
  4. Node.js使用了一个事件驱动、非阻塞式I/O的模型,使其轻量又高效

    • Node.js功能

      • 事件驱动
      • 非阻塞I/O模型【 异步的输入输出,比如: 文件操作、数据库操作 等 】

Node.js文件的运行?

  1. 使用Node.js编译器
  2. 使用命令运行

Node.js文件的实时监听改动

  1. nodemon

Node.js版本

  1. Current [ 最新的版本 ] - 小白鼠
  2. LTS - 长期稳定版本

Node.js的模块化问题

  1. Node.js采用了Common.js模块化
  2. 应用
    • 内置模块 -> 可以直接使用
const fs = require('fs') // Common.js 模块引入方式
/*
* fs 是一个对象
* 定义的fs 其实拿的是一个地址,地址我们希望是稳定不变的,所以const
*/ // fs.readFileSync // 同步读
// fs.readFile // 异步读
  • 第三方模块 -> Node.js没有的 类似于插件
/*
* 类似插件
* 我们现在想在我们的当前文件中引入带有功能的插件
* 前端第三方模块全部都在一个网站中: www.npmjs.com
* 使用
* 1. 安装【 npm/cnpm/yarn 】
* 2. cnpm i request -S/-D
* -S 生产环境
* -D 开发环境
*
* 问题: 这里是否存在跨域?
* 不存在 Node.js是运行在服务端的,不是浏览器端,没有同源策略
*
! 总结
! 第三方模块使用? 将来别人项目中使用了你没有用过的东西,怎么办?
! 1. npm.js 查阅文档
! 2. 先写单案例测试
! 3. 记录使用文档,记录自己博客中 */ const request = require('request') request('https://m.lagou.com/listmore.json', function (error, response, body) {
console.log('error:', error);
console.log('statusCode:', response && response.statusCode);
console.log('body:', body);
});
  • 自定义模块
/*
* 自定义模块
* 自己创建模块,自己使用
* 类型:
* 1. 函数
* 2. 对象
* 3. 字符串
*/ // 1. 定义模块
const people = {
name: '西阁',
sex: 'man',
age: 18
} // 2. 导出模块 module.exports = people
// 3. 自定义模块导入
const people = require('./3-自定义模块定义.js') console.log('people.name:', people.name )
  1. 模块化解决的是什么问题?

    • js中可以引用其他类型文件(html css sass )
  2. 自定义模块上传实现步骤 【 公司中应用比较多 】

      1. 创建文件夹,注意命名不要冲突
      1. 创建package.json文件
      • npm init / npm init -y
      1. 创建了 index.js, 里面封装任意一个功能
      1. 创建一个 npm.js 账号
      • 发送一个邮箱连接激活【 手动点 】
      1. 保证我们当前的源是 npm 源
      • $ nrm use npm
      1. 登录账号
      • $ npm adduser
      1. 上传
      • $ npm publish

JSON.stringify / JSON.parse

  1. 字符串、对象互相转换
  2. 拷贝
const fs = require('fs')
const data = fs.readFileSync('./data.json','utf8')//字符串
const newData = JSON.parse( data )//将JSON字符串转为一个对象
const newStr = JSON.stringify( newData )//将 JavaScript 对象转换为 JSON 字符串
const state = {
msg: '千锋教育',
obj: {
x: 1,
y: 2
}
}
// 深拷贝 -> 1. 递归 2. JSON序列化实现
const newState = JSON.parse(JSON.stringify( state ))
newState.msg = " hello Node.js "
console.log('state',state)
console.log('newState',newState)

querystring 内置模块

  1. 使用场景

    • 用于处理url上的查找字符串
/*
! querystring - 应用场景: 处理url查找字符串
! 1. querystring.parse string -> object
! 2. querystring.stringify object -> string
! 3. querystring.escape 中文转码
! 4. querystring.unescape 中文解码
*/
const qs = require('querystring')
const url = require('url')
// console.log("西阁: qs", qs)
// ! 1. parse
const str = 'https://detail.tmall.com/item.htm?spm=a230r.1.14.6.7a344d82XrCvx0&id=604098442154&cm_id=140105335569ed55e27b&abbucket=2'
const newObj = qs.parse(url.parse( str ).query,'&','=')
// console.log("西阁: newObj", newObj)
/*
{
spm: 'a230r.1.14.6.7a344d82XrCvx0',
id: '604098442154',
cm_id: '140105335569ed55e27b',
abbucket: '2'
}
*/ // ! 2. stringify
const newStr = qs.stringify( newObj )
// console.log("西阁: newStr", newStr) // ! 3. escape const str1 = 'city=北京' const city = qs.escape( str1 )
console.log("西阁: city", city) // city%3D%E5%8C%97%E4%BA%AC // !4. unescape const cityCape = qs.unescape( city )
console.log("西阁: cityCape", cityCape)

path

  1. 使用场景

    • 用于处理绝对路径/磁盘路径
  2. 问题: 浏览器中全局对象是?Node.js全局变量?
    • 浏览器中全局对象: window
    • Node.js全局变量: global
const path = require('path')
console.log("西阁: path", path) // console.log( __dirname ) // 全局变量
/* e:\1911\1-Node.js\day01\code\5-内置模块 */ // const pathUrl = path.join( __dirname, 'aa')
const pathUrl = path.resolve( __dirname, 'aa')
console.log("西阁: pathUrl", pathUrl)

Node.js概述1的更多相关文章

  1. Node.js 概述

    JavaScript 标准参考教程(alpha) 草稿二:Node.js Node.js 概述 GitHub TOP Node.js 概述 来自<JavaScript 标准参考教程(alpha) ...

  2. Node.js概述

    Node.js最重要的特性:通过单线程实现异步处理环境 Node.js解决的问题: Node.js修改了客户端连接服务器端的连接方法,不需要为每个客户端连接创建一个新的线程,而是为每个客户端连接触发一 ...

  3. Node.js—概述

    一.Node.js与其他语言对比   Node.js不是一种独立的语言,与PHP.JSP.Python.Perl.Ruby的"既是语言,也是平台"不同,Node.js的使用Java ...

  4. Node.js权威指南 (1) - Node.js介绍

    1.1 Node.js概述 / 2 1.1.1 使用Node.js能够解决什么问题 / 2 1.1.2 实现高性能服务器 / 2 1.1.3 非阻塞型I/O及事件环机制 / 2 1.1.4 Node. ...

  5. 第 1 章 Node.js 介绍

    本章内容包括: 什么是 Node.js 框架,为什么要用 Node.js 框架,使用 Node.js 框架能够解决什么问题,在哪些场合下应该考虑使用 Node.js 框架. 如何下载 Node.js ...

  6. NodeJs>------->>第一章:Node.js介绍

    一:章节前言 二:Node.js概述 1:使用node.js能够解决什么问题 2:实现高性能服务器 3:非阻塞型I/O及事件环形机制 4:node.js适合开发的程序 三:node.js安装 一.No ...

  7. 《Node.js核心技术教程》学习笔记

    <Node.js核心技术教程>TOC \o "1-3" \h \z \u 1.章模块化编程 2019.2.19 13:30' PAGEREF _101 \h 1 08D ...

  8. Node.js实战(一)之概述

    , 一.Node.js介绍 Node.js是一个Javascript运行环境(runtime environment),发布于2009年5月,由Ryan Dahl开发,实质是对Chrome V8引擎进 ...

  9. 基于node.js+socket.io+html5实现的斗地主游戏(1)概述

    一.游戏描述 说是斗地主游戏,其实是寝室自创的"捉双A",跟很多地方的捉红10.打红A差不多,大概规则是: 1.基础牌型和斗地主一样,但没有大小王,共52张牌,每人13张,这也是为 ...

随机推荐

  1. 自建免费的代理ip池

    00x01--- 前言 因为爬虫被禁ip这样的反扒真的很凶,但自从建了一个代理ip池以后,反反扒就可以跟的上节奏.当然你也可以上网上各种代理平台自己付费.这些平台当然很方便提供api调用,还不用自己验 ...

  2. sqlserver存储过程事务回滚

    set ANSI_NULLS ON set QUOTED_IDENTIFIER ON go ALTER PROCEDURE [dbo].[AddUserOnChannel] ), ), @Channe ...

  3. cannot be cast to javax.servlet.Servlet 解决

    使用maven创建web项目的时候,通过添加依赖的方式来添加servlet-api,如下 通过maven的命令(tomcat:run)来启动项目,发现访问的时候报错,错误如下: 错误排查: 首先查看s ...

  4. git异常处理(一)

    请输入提交消息来解释为什么这种合并是必要的 git 在pull或者合并分支的时候有时会遇到这个界面.可以不管(直接下面3,4步),如果要输入解释的话就需要: 1.按键盘字母 i 进入insert模式 ...

  5. TFS2013 微软源代码管理工具 安装与使用图文教程

    最近公司新开发一个项目要用微软的TFS2013进行项目的源代码管理,以前只是用过SVN,从来没有用过TFS,所以在网上百度.谷歌了好一阵子来查看怎么安装和配置,还好花了一天时间总算是初步的搞定了,下面 ...

  6. ArcGIS Server 10.1安装、配置、发布地图服务

    先跟大家分享一个esri的学习资料,http://pan.baidu.com/s/1nBzxB,<ArcGIS10.1 for Server 入门教程>.教程讲述的很清楚,下面说说我这次发 ...

  7. 深入浅出 Java Concurrency (4): 原子操作 part 3 指令重排序与happens-before法则[转]

    在这个小结里面重点讨论原子操作的原理和设计思想. 由于在下一个章节中会谈到锁机制,因此此小节中会适当引入锁的概念. 在Java Concurrency in Practice中是这样定义线程安全的: ...

  8. WPF DataGrid 数据绑定之"List配合Dictionary"

    WPF 的DataGrid是WPF中最为强大的控件之一,可以通过各种方式绑定 例如通过最为形似的dataTable来绑定 本文则用List<Dictionary<K,V>>来绑 ...

  9. Maven中央仓库地址大全,Maven中央仓库配置示例

    < Maven 中央仓库地址大全 > 在上一篇文章中完成了 < Maven镜像地址大全 >,后来又花了时间又去收集并整理了关于 maven 远程仓库地址,并整理于此,关于 Ma ...

  10. springboot 2 Hikari 多数据源配置问题(dataSourceClassName or jdbcUrl is required)

    springboot 2 Hikari 多数据源配置问题(dataSourceClassName or jdbcUrl is required) 最近在项目中想试一下使用 Hikari 连接池,以前用 ...