NodeJS 后端开发 01 创建项目与运行helloworld

简介: 本篇是 雷学委的NodeJS系列 的第一篇。

关于NodeJS

NodeJS是一个基于Chrome V8引擎的JavaScript运行环境,一个让JavaScript运行在服务端的开发平台;


它用于方便地搭建响应速度快、易于扩展的网络应用。


其他概念不重要,作为一个新手,这里只要记住NodeJS基于一个引擎来运行的环境,这引擎就是下文的node程序来启动的。


小白可能看不懂了,那就先把NodeJS就是一个代码执行器,我们后面写代码都得用这个来运行。


代码就是NodeJS软件能读懂的语言,跟我们说中文,英文一样的。


但是NodeJS是外国来的,它天生就不懂中文,所以新手写的代码的时候,尽量不要出现中文也不要用中文输入法(这有可能让你的代码出现中文符合,程序错误)!


前端的同学经常回看到命令:npm run start 或npm run dev等等。


然后自动打开了一个浏览器窗口,加载了当前项目编译好的前端UI代码。这个进程运行的就是NodeJS引擎。


下面先安装Node软件吧,初步使用一下node程序。


下载与安装

https://nodejs.org/zh-cn/download/ or

https://nodejs.org/zh-cn/download/releases/


版本一般选择最新即可,window操作系统选择exe安装。


推荐使用zip或者tar.gz方式,然后参考下面设置到环境变量PATH的方式。

set PATH=%NODEJS_HOME%:%PATH%

通过手动设置这种方式,可以让你会更熟悉node/npm配置。以后玩vue cli或者angularreact-script都很有帮助。

安装成功可以通过下面命令查看:

image.png

本文使用的版本从这里下载:https://nodejs.org/download/release/v12.18.0/,苹果电脑 macbook选择pkg包

安装好后,打开cmd(命令行)或者苹果电脑打开terminal(终端),输入node

image.png

这直接就进入了对接NodeJS引擎的交互终端了。


给小白的提示:交互终端就是在线写代码运行代码的窗口


特别注意:下面输入程序的时候,不要有中文符号,因为NodeJS毕竟出生在国外,肯定不懂中文,运行就会出错!


开始写NodeJS代码

编写第一行代码

直接复制下面一行代码:

console.log("hello,雷学委!")  

效果如下,也可以参考下面继续试着输入一个表达式:1+1

image.png

NodeJS来做一道应用题

在数学中定义变量就是如下:

已知:x=4, y=20,求 y由几个x相加而得到?

这道应用题大家都见过吧,下面用编程来表达。

我们继续在上面的node窗口中输入下面三行:

x=4
y=20
u=y/x

image.png

是不是很方便变量u的值5,就是我们要求解问题的答案!

这些只是简单的使用。

NodeJS来做一个函数

数学中,我们都学习过函数这个概念,比如y=2x + 5 代表一个直线。

知道随意一个x值就能够求出y的值。那这个用程序怎么做呢?

image.png

好了自己试试吧。


创建一个新项目

什么是项目?


项目简单理解就是一个文件夹,它包含了一些代码文件(如js结尾的文件)。


我们把整个目录的文件看成一个整体就是项目。


做的好的项目还能分享给程序员使用!通常分享给别人的项目我们称作库(代码库),后面统一用JS库代指。


稍微看一下概念,打开命令终端输入:npm init


如下图,中间过程会有提示很多输入选项,重点关注package(包) 和version(版本号)。


这两个就像身份证好一样的东西,可以让其他开发者找到你的项目。

image.png

为啥项目需要给定package和版本号?

如果很多作业考试题目都有一个package和version来定位?


那么我想要找到一道题目的答案就能通过pacakge + version来定位到了。


在NodeJS的开发社区中,有一个网站叫做npm registry: https://www.npmjs.com/


这个网站登记了所有NodeJS对外分享开源的JS库,有空多去搜搜看。


如果我们想要复用别人项目做好的功能,那么通过package和版本号就能定位到。


通过这两个定位找到别人的代码来使用,相当于抄作业了,别人写一个正确的版本给你哦


(千万要记得去点赞转发支持,这会鼓励更多人发布分享更多的JS库)


image.png

image.png

当我们项目需要引用其它JS库的时候,可以明确给定某个”库@版本“进行定位。

比如下图package.json dependencies引用了koa这个库。

image.png

开发第一个NodeJS项目

编写app.js或者index.js

image.png

刚才我们创建项目时,通过设置main属性,指定了app.js文件作为入口。

所以这里我们编写一个app.js, 具体如下图的代码,

image.png

解释一下:console.log 是NodeJS内置提供的一个JS函数,我们可以使用它来打印内容输出到终端。


然后可以使用node app.js 执行。记住,执行一个js文件使用命令:node 文件名.js


这就是一个最简单的JS库了,只是用来打印内容,我们没有引用别人的JS库。


进一步工程化

很多nodejs项目通常可以使用npm start或者npm run start.


这里我们可以在package.json 中进行修改,如下图第八行所示。

image.png

”npm run start” 或者更早版本“npm start”,nodejs会解析package.json查找scripts属性下的“start”属性对应的命令,等价于执行node app.js。


通常可以看的很多项目中有“build”,“test", "build-prod"等等应对nodejs项目构建测试的一些scripts,可以自己尝试添加更多scripts字属性验证。


先到这里,上图为第一个nodejs项目的执行效果。这个示例很简单:app.js写了代码调用console.log输出"hello nodejs 001"。


回顾这个项目

我们打开package.json, 它定义了这个项目的name,version和描述。


这文件也定义了程序入口(main),同时其它包括作者(author)项目地址等信息。

image.png

package.json还能定义项目的一些引用的js库(依赖的JS项目)。


这个在下篇会继续展示,同时使用nodejs制作API也就是提供数据接口的示例。


对了,学委还有这个可以关注长期阅读 =>雷学委趣味编程故事汇编

或者=> 雷学委NodeJS系列


当前示例项目仓库:https://codechina.csdn.net/geeklevin/nodejs-001


目录
相关文章
|
5月前
|
人工智能 Java API
后端开发必看:零代码实现存量服务改造成MCP服务
本文介绍如何通过 **Nacos** 和 **Higress** 实现存量 Spring Boot 服务的零代码改造,使其支持 MCP 协议,供 AI Agent 调用。全程无需修改业务代码,仅通过配置完成服务注册、协议转换与工具映射,显著降低改造成本,提升服务的可集成性与智能化能力。
1560 1
|
5月前
|
前端开发 Java 数据库连接
后端开发中的错误处理实践:原则与实战
在后端开发中,错误处理是保障系统稳定性的关键。本文介绍了错误分类、响应设计、统一处理机制及日志追踪等实践方法,帮助开发者提升系统的可维护性与排障效率,做到防患于未然。
|
7月前
|
存储 消息中间件 前端开发
PHP后端与uni-app前端协同的校园圈子系统:校园社交场景的跨端开发实践
校园圈子系统校园论坛小程序采用uni-app前端框架,支持多端运行,结合PHP后端(如ThinkPHP/Laravel),实现用户认证、社交关系管理、动态发布与实时聊天功能。前端通过组件化开发和uni.request与后端交互,后端提供RESTful API处理业务逻辑并存储数据于MySQL。同时引入Redis缓存热点数据,RabbitMQ处理异步任务,优化系统性能。核心功能包括JWT身份验证、好友系统、WebSocket实时聊天及活动管理,确保高效稳定的用户体验。
464 4
PHP后端与uni-app前端协同的校园圈子系统:校园社交场景的跨端开发实践
|
7月前
|
Java 关系型数据库 MySQL
在Linux平台上进行JDK、Tomcat、MySQL的安装并部署后端项目
现在,你可以通过访问http://Your_IP:Tomcat_Port/Your_Project访问你的项目了。如果一切顺利,你将看到那绚烂的胜利之光照耀在你的项目之上!
421 41
|
8月前
|
前端开发 JavaScript 关系型数据库
2025 年前端与后端开发方向的抉择与展望-优雅草卓伊凡
2025 年前端与后端开发方向的抉择与展望-优雅草卓伊凡
614 5
2025 年前端与后端开发方向的抉择与展望-优雅草卓伊凡
|
8月前
|
人工智能 小程序 NoSQL
【一步步开发AI运动小程序】二十一、如何将AI运动项目配置持久化到后端?
本文介绍基于云智「Ai运动识别引擎」的运动配置持久化方案,旨在优化小程序或Uni APP中AI运动识别能力。通过将运动检测参数(如`Key`、`Name`、`TickMode`、`rules`或`samples`)持久化到后端,可避免因频繁调整运动参数而重新发布应用,提升用户体验。持久化数据结构支持规则和姿态样本存储,适用于关系数据库、文件或文档数据库(如MongoDB)。此外,云智还提供运动自动适配工具及「AI乐运动」产品,助力快速实现AI体育、全民健身等场景。
|
8月前
|
JavaScript 安全 前端开发
关于Node.js,一定要学这个10+万Star项目 !!
一篇关于Node.js的宝藏项目——Node.js Best Practices。该项目在GitHub上已有102k Star,汇集了100+条最佳实践,涵盖架构、安全、性能等多方面。每条实践不仅有简明说明和详细解释,还附带代码示例及资源链接。文中通过三个实战案例(利用CPU多核、避免阻塞事件循环、使用中间件处理错误)展示了其实际应用价值,并推荐了几条对前端转Node.js开发者特别有用的最佳实践。强烈建议每位Node.js开发者学习此项目,理解“怎么做”与“为什么要这么做”,以提升开发能力。
312 3
|
9月前
|
JSON 自然语言处理 前端开发
【01】对APP进行语言包功能开发-APP自动识别地区ip后分配对应的语言功能复杂吗?-成熟app项目语言包功能定制开发-前端以uniapp-基于vue.js后端以laravel基于php为例项目实战-优雅草卓伊凡
【01】对APP进行语言包功能开发-APP自动识别地区ip后分配对应的语言功能复杂吗?-成熟app项目语言包功能定制开发-前端以uniapp-基于vue.js后端以laravel基于php为例项目实战-优雅草卓伊凡
515 72
【01】对APP进行语言包功能开发-APP自动识别地区ip后分配对应的语言功能复杂吗?-成熟app项目语言包功能定制开发-前端以uniapp-基于vue.js后端以laravel基于php为例项目实战-优雅草卓伊凡
|
存储 缓存 负载均衡
后端开发中的性能优化策略
本文将探讨几种常见的后端性能优化策略,包括代码层面的优化、数据库查询优化、缓存机制的应用以及负载均衡的实现。通过这些方法,开发者可以显著提升系统的响应速度和处理能力,从而提供更好的用户体验。
432 6
|
消息中间件 运维 安全
后端开发中的微服务架构实践与挑战####
在数字化转型的浪潮中,微服务架构凭借其高度的灵活性和可扩展性,成为众多企业重构后端系统的首选方案。本文将深入探讨微服务的核心概念、设计原则、关键技术选型及在实际项目实施过程中面临的挑战与解决方案,旨在为开发者提供一套实用的微服务架构落地指南。我们将从理论框架出发,逐步深入至技术细节,最终通过案例分析,揭示如何在复杂业务场景下有效应用微服务,提升系统的整体性能与稳定性。 ####
250 32

热门文章

最新文章