Node.js | 从前端到全栈的必经之路

简介: 深入浅出Node.js,最适合前端开发人员进入全栈时学习的服务端语言,以JavaScript为基础,使前端人员能够平滑过渡到全栈,赶快来认识一下Node.js吧!

前言

对于前端开发的朋友们,是否有这样的烦恼或需求:

  • 想要开发一个心仪的项目但没有后端朋友的合作,而只能使用mock
  • 与后端合作开发中总感觉约束,不能很好的交流所想,从而拖慢进度?
  • 不甘心自己只能和他人合作开发,想要自己独立实现效果?
  • 想提高自己的地位,丰富自己的知识面,从而能够在团队中独当一面?
  • 习惯了个人开发,自由惯了,不想随波逐流服从安排?
  • 等等

当你有这些问题时,就该是时候问问自己是不是想要发展为全栈,如果是,那么学习Node.js就该是你进击全栈的必经之路!

一、什么是Node

Node.js是一个javascript运行环境,它让javascript可以开发后端程序,实现几乎其他后端语言实现的所有功能!

这意味着我们只需要掌握javaScript一门语言就能够进行全栈开发

学习 Node我们可以非常平滑的过渡到全栈开发,并且如果你之前学习过 VueReact等前端框架或者 Webpack这些,那么其实你就已经接触过Node了,因为它们都是建立于Node基础上的,如:
Vue、React的脚手架:Vue-cli,create-react-app,vite等(这也就是为什么使用这些框架时需要安装Node环境)

对于前端开发经常用的npm,它是NodeJS包管理和分发工具,其实就相当于是Node的开源仓库(并且是全球最大的开源仓库
我们可以使用npm指令去下载这个仓库里的指定项目进行使用(如运行npm i axios 下载这个仓库里的axios
当然我们也可以开发自己的插件项目通过npm指令上传到这个仓库里

👉Node.js的由来

Node.js基于V8引擎,而V8其实是Google发布的开源JavaScript引擎,本身是用于Chrome浏览器的js解释部分,但是总有大佬不按套路出牌,Node之父Ryan Dahl就把这个V8搬到了服务器上,用于做服务器的软件

Node.js发布于2009年5月,经过十几年的发展,它已经成为前端中顶梁柱的存在,就算你不需要它进行服务端开发,它也存在于你开发过程中的方方面面,如前面提到的VueReactWebpack

👉Node.js的特性

  • Node.js贯穿于客户端(如Vue这类框架的底层依赖)和服务端(如后端开发)
  • Node.js的语法完全就是javascriptES6的语法
  • Node.js具有超强的高并发能力,能够实现高性能服务器
  • 开发周期短、开发成本低、学习成本低

单论后端开发,Node.js作为JavaScript的运行环境的性能虽不能与Java这类编译语言相比,但它独有的特性完全可以弥补这性能的差距,甚至能够进行超越!这也就是为什么它能够发展如此之快,能够受到越来越多人青睐的原因!

看到这里你可能已经明白,为什么我会说Node是前端到全栈的必经之路

二、浏览器环境与Node环境对比

看图:

在这里插入图片描述

图画的不好,凑合着看(操作系统包括网卡/硬盘/本地文件等等,一般是windows或max或linux等等)

从图上看,好像Node环境就只是浏览器环境的一部分,但其实不然,在浏览器环境中我们很难触控到操作系统那一层,这是因为具有浏览器安全级别的限制(不限制的话,浏览器上的网页就能直接操控操作系统,这还能了得?)

Node.js作为JavaScript的服务端运行环境,它可以解析JavaScript代码(没有浏览器安全级别的限制),并能够为其提供很多系统级别的API,如:

  • 系统文件的读写(fs
  • 系统进程的管理(process
  • 网络通信 (HTTP/HTTPS)
  • 等等
这些将在之后的文章中一一讲解,赶快订阅 Node.js从入门到精通专栏追更吧!

但这也同样代表在Node.js中我们无法使用浏览器提供的API,如window对象,更不能操作DOM元素

三、搭建Node环境

如果你曾使用过npm,或者前端框架,相信你已经搭建好了Node的环境,这里对没有搭建过的朋友们再次演示一下:

打开Node官网:https://nodejs.org/zh-cn/

在这里插入图片描述
推荐下载这个长期维护的稳定版本,下载完成后一路Next安装即可

之后在任意位置终端运行: node -v

在这里插入图片描述

出现版本号了就代表我们已经安装成功了

我这里安装的比较久了,所以版本号会比较老,不影响使用

四、体验Node模块化开发

在一个文件夹内随便建两个js文件,如下:

在这里插入图片描述

因为Node的语法就是JavaScript的语法,所以使用Node进行模块化开发的方式依旧是使用CommonJSES Modules,这里直接就进行演示,不再细说

👉CommonJS方式

Node默认是CommonJS方式:

// index.js
const name = "Ailjx";
// 导出方法一:module.exports直接导出
// 直接对module.exports赋值时,main.js中导入的就是这个赋值
// 多个module.exports赋值时,只生效最后一个,即最后一个会替代前面的
module.exports = name;

在这里插入图片描述

在文件夹终端运行node js文件路径命令就能使用node来运行指定的js文件,console.log打印结果在终端进行显示

每次修改main.js文件后需要重新运行命令node .\main.js执行main.js文件,这显然不太方便,我们可以安装nodemon这个插件来帮我们自动运行

npm i nodemon -g

之后使用nodemon运行main.js

nodemon .\main.js

其它的导出语法:

// index.js
const name = "Ailjx";

// 导出方法一:module.exports直接导出
// 直接对module.exports赋值时,main.js中导入的就是这个赋值
// 多个module.exports赋值时,只生效最后一个,即最后一个会替代前面的
module.exports = name;

// 导出方法二:module.exports导出对象
// main.js里n接受的是一个对象{ NNNN: 'Ailjx' }
module.exports = {
    NNNN: name, // 顺便起个别名
    // 可以继续导出其它内容
};

// 导出方法三:exports.key值=内容
// main.js里n接受的是一个对象{ Myname: 'Ailjx', Myname2: 'Ailjx' }
// 使用多个 exports.key值=内容 时最终会合并成一个大对象(相同key值的会覆盖),而不是像多个module.exports赋值时,只生效最后一个
// exports.key值与module.exports一起使用时会被module.exports替代
exports.Myname = name;
exports.Myname2 = name;

// 导出方法四:exports.key值=对象
// main.js里n接受的是一个对象:{ Myname: { A: 'Ailjx' } }
exports.Myname = {
    A: name, // 顺便起个别名
    // 导出其它内容
};

👉ES Modules方式

因为node默认是使用CommonJS规范,所以我们在使用ES Modules时需要进行配置一下

先在文件夹下运行npm init生成package.json文件:

在这里插入图片描述

运行npm init后会一个个的让你输入信息,按照上图提示填即可,最后生成的package.json文件如下:

{
  "name": "node",
  "version": "1.0.0",
  "description": "node学习",
  "main": "main.js",
  "scripts": {
    "test": "echo \"Error: no test specified\" && exit 1"
  },
  "author": "Ailjx",
  "license": "MIT"
}

我们在 package.json中加上一行 "type": "module",即可切换使用ES Modules方式,这时就不能再使用CommonJS方式了(二选一

不太建议使用 ES Modules,因为 npm仓库里的包大多遵循的是 CommonJS规范,如果你使用 ES Modules,去下载这些包时很可能会出现 不兼容

语法:

const name = "Ailjx";

// 接口暴露方法一:export default默认导出
// 一个文件只能有一个export default
// main.js使用:import n from "./index.js";进行导入,n自己随便起名,它的值为Ailjx
// export default name;

// 接口暴露方法二:export导出对象
// main.js使用:import { MyName } from "./index.js";进行导入
export {
    name as MyName, // 顺便使用as改个别名
    // 导出其它成员
};

// export default 可以和 export导出对象 一起使用,一起使用时:
// main.js使用:import n, { MyName } from "./index.js";进行导入,n和MyName的值都为Ailjx

结语

只学习 Node,并不能让你真正的发展为全栈大佬,学习 Node只是让前端人员能够非常快,非常丝滑的 过渡到全栈,为之后的学习发展奠定基础,如果想要成为真正的全栈大佬,像 Java这类的编译语言以及一些其它方面的技术肯定还是要学习的

这篇文章主要介绍了一下什么是Node,以及Node环境的配置,之后我们就将开始深入去学习Node了,关注博主,订阅专栏,学习Node不迷路!

如果本篇文章对你有所帮助,还请客官一件四连!❤️

相关文章
|
20天前
|
JavaScript 前端开发 程序员
前端原生Js批量修改页面元素属性的2个方法
原生 Js 的 getElementsByClassName 和 querySelectorAll 都能获取批量的页面元素,但是它们之间有些细微的差别,稍不注意,就很容易弄错!
|
1月前
|
Cloud Native 前端开发 JavaScript
前端开发者必看:不懂云原生你就OUT了!揭秘如何用云原生技术提升项目部署与全栈能力
【10月更文挑战第23天】随着云计算的发展,云原生逐渐成为技术热点。前端开发者了解云原生有助于提升部署与运维效率、实现微服务化、掌握全栈开发能力和利用丰富技术生态。本文通过示例代码介绍云原生在前端项目中的应用,帮助开发者更好地理解其重要性。
66 0
|
17天前
|
JavaScript 前端开发 Java
springboot解决js前端跨域问题,javascript跨域问题解决
本文介绍了如何在Spring Boot项目中编写Filter过滤器以处理跨域问题,并通过一个示例展示了使用JavaScript进行跨域请求的方法。首先,在Spring Boot应用中添加一个实现了`Filter`接口的类,设置响应头允许所有来源的跨域请求。接着,通过一个简单的HTML页面和jQuery发送AJAX请求到指定URL,验证跨域请求是否成功。文中还提供了请求成功的响应数据样例及请求效果截图。
springboot解决js前端跨域问题,javascript跨域问题解决
|
19天前
|
缓存 JavaScript 前端开发
JavaScript 与 DOM 交互的基础及进阶技巧,涵盖 DOM 获取、修改、创建、删除元素的方法,事件处理,性能优化及与其他前端技术的结合,助你构建动态交互的网页应用
本文深入讲解了 JavaScript 与 DOM 交互的基础及进阶技巧,涵盖 DOM 获取、修改、创建、删除元素的方法,事件处理,性能优化及与其他前端技术的结合,助你构建动态交互的网页应用。
28 5
|
16天前
|
前端开发 JavaScript 关系型数据库
基于 Vue2.0 + Nest.js 全栈开发的后台应用
Vue2 Admin 是一个基于 Vue2 和 Ant Design Pro 开发的前端项目,配合 Nest.js 构建的后端,提供了一个完整的全栈后台应用解决方案。该项目支持动态国际化、用户权限管理、操作日志记录等功能,适合全栈开发者学习参考。线上预览地址:https://vue2.baiwumm.com/,用户名:Admin,密码:abc123456。
|
17天前
|
缓存 前端开发 JavaScript
JavaScript前端路由的实现原理及其在单页应用中的重要性,涵盖前端路由概念、基本原理、常见实现方式
本文深入解析了JavaScript前端路由的实现原理及其在单页应用中的重要性,涵盖前端路由概念、基本原理、常见实现方式(Hash路由和History路由)、优点及挑战,并通过实际案例分析,帮助开发者更好地理解和应用这一关键技术,提升用户体验。
47 1
|
21天前
|
JSON 前端开发 JavaScript
聊聊 Go 语言中的 JSON 序列化与 js 前端交互类型失真问题
在Web开发中,后端与前端的数据交换常使用JSON格式,但JavaScript的数字类型仅能安全处理-2^53到2^53间的整数,超出此范围会导致精度丢失。本文通过Go语言的`encoding/json`包,介绍如何通过将大整数以字符串形式序列化和反序列化,有效解决这一问题,确保前后端数据交换的准确性。
31 4
|
1月前
|
机器学习/深度学习 自然语言处理 前端开发
前端神经网络入门:Brain.js - 详细介绍和对比不同的实现 - CNN、RNN、DNN、FFNN -无需准备环境打开浏览器即可测试运行-支持WebGPU加速
本文介绍了如何使用 JavaScript 神经网络库 **Brain.js** 实现不同类型的神经网络,包括前馈神经网络(FFNN)、深度神经网络(DNN)和循环神经网络(RNN)。通过简单的示例和代码,帮助前端开发者快速入门并理解神经网络的基本概念。文章还对比了各类神经网络的特点和适用场景,并简要介绍了卷积神经网络(CNN)的替代方案。
|
1月前
|
移动开发 前端开发 JavaScript
前端实训,刚入门,我用原生技术(H5、C3、JS、JQ)手写【网易游戏】页面特效
于辰在大学期间带领团队参考网易游戏官网的部分游戏页面,开发了一系列前端实训作品。项目包括首页、2021校园招聘页面和明日之后游戏页面,涉及多种特效实现,如动态图片切换和人物聚合效果。作品源码已上传至CSDN,视频效果可在CSDN预览。
31 0
前端实训,刚入门,我用原生技术(H5、C3、JS、JQ)手写【网易游戏】页面特效
|
1月前
|
JavaScript 前端开发 开发者
前端框架对比:Vue.js与Angular的优劣分析与选择建议
【10月更文挑战第27天】在前端开发领域,Vue.js和Angular是两个备受瞩目的框架。本文对比了两者的优劣,Vue.js以轻量级和易上手著称,适合快速开发小型到中型项目;Angular则由Google支持,功能全面,适合大型企业级应用。选择时需考虑项目需求、团队熟悉度和长期维护等因素。
41 1