关键词:
nodejs基础
接上一篇:nodejs入门
第三方模块
就是网上别人已经开发好的模块,我们可以直接拿来借鉴使用,但是需要下载,下载工具使用npm。
npm工具
下载:
npm install/i 包名
npm i 包名 包名 ...
npm i 包名@版本号 # 最新版本可以使用 @latest - 版本号不用写全
npm i 全局工具 --gloabl # 简写 npm i 全局工具 -g
下载命令执行之后,会生成node_modules文件夹,将下载好的包放在这个文件夹中。
这个文件夹的特点:文件比较琐碎,层级嵌套较深,依赖关系较多…
查看所有安装好的局部包:
Npm list - npm ls - 局部的
Npm list -g - 全局包
npm安装git上发布的包:
npm i git+仓库地址
npm i github:模块(包)名称
卸载:
npm uninstall/un 包名
Npm un 包
Npm un 包 -g
下载/卸载参数:
–save-dev 简写 -D 表示下载的这个包是一个开发依赖,将来上线后将不需要,只是在本地开发阶段需要
–save 简写 -S 表示下载的这个包是一个生产依赖,将来项目上线后还需要,本地开发和远程上线都需要,npm默认使用–save参数
–global 简写 -g 表示下载的这个包是一个命令,需要在计算机任何一个位置都能使用
补充:
npm i命令默认会将开发依赖安装上,只安装生产依赖不安装开发依赖的话,就在安装依赖包的时候,加参数:npm install --production
初始化:
npm init # 手动输入整个包的信息
npm init -y # 自动生成整个包的信息 - 不能在中文文件夹下使用
# 初始化命令执行以后,会生成package.json文件,生成后在当前目录下安装的所有包,都会自动记录在这个文件中,方便查看、下载、卸载、分析等操作
npm install/i # 安装所有package.json中记录好的包,只安装生产依赖(之前用过-S),不安装开发依赖(之前安装用-D)
初始化的原因:
我们在开发的时候需要依赖很多包,等开发完成后,项目需要上传到服务器环境下运行上线,但node_modules文件夹由于自身的特点,不方便上传,可能在上传过程中造成文件无法上传或文件丢失等问题,所以,我们将项目中依赖的包记录在package.json文件中,在服务器环境中根据记录的包的信息,再次下载即可。
npm切换镜像源:
npm config set registry 镜像源地址 # 切换命令
npm config get registry # 查看镜像源地址
npm --registry https://registry.npm.taobao.org install node-red-contrib-composer@latest # 临时切换使用
修改生产环境和开发环境:
npm config set production true
# npm默认有一个配置是在生产环境下,将production设置为false的时候,就将环境改成开发环境了
查看npm配置项:
npm config list
查看所有全局包:
npm list -g
清除缓存:
npm cache clear --force/-f
查看包的所有版本:
npm view 包名 versions
更新包:
npm update 包名
npm和cnpm的区别:
npm下载默认会把包安装到生产依赖,但是cnpm不会(cnpm默认不记录)
查看包的使用方式:https://www.npmjs.com/
上传自己的包:
-
npm初始化
注意:自己的包名称不能跟已有的包名称产生冲突
-
写自己代码
-
分两种情况:
-
第一次发布
npm adduser # 设置登录信息
然后根据提示输入自己的账号、密码、邮箱
npm publish # 发布
第一次提交会报错,报错是需要验证一下邮箱,所以需要登录邮箱,验证一下。完成验证后,继续发布。
-
-
非第一次发布
npm login # 登录
然后根据提示输入自己的账号、密码、邮箱
npm publish # 发布
发布时,镜像源要使用npm
取消已发的包:
将待取消发布的包下载下来,进入node_modules文件夹中的这个包的目录中
npm unpublish --force
如果版本较多,只能取消其中最后一个版本,取消指定版本的发布:
npm unpublish 包名@版本号 --force
当我们,对自己的包做了修改时,更改package.json中的版本号,package.json中的version字段,再次发布即可。版本格式:主版本号.次版本号.修订号
,版本号递增规则如下:
修改一丢丢项目,不影响之前的使用,那就递增修订号
新增了功能,那就递增次版本号,不影响之前的使用
如果修改的很多,或新增/修改了一些影响之前使用的东西,那就递增主版本号
注意:取消发布的包,他的名称也不能被占用了。
nrm工具
主要用于操作镜像源。下载安装:
npm i nrm -g
检测版本:
nrm --version # 简写 nrm -v
有的nrm下载好检测版本的时候会报错:
此时对目标报错文件进行修改:
nrm命令:
nrm ls # 查看所有镜像源
nrm test # 检测每个镜像源的连接速度
nrm use 指定镜像源名称 # 切换镜像源
自定义模块
可以让一个js中导入另一个js中的数据,导入语法:
require(被导入的文件路径)
注意:
被导入的文件路径如果有
./
则必须加,不加系统会默认为内置模块被导入的文件路径中的文件后缀可以省略
导出语法:
exports.键 = 值
module.exports.键 = 值
module.exports =
注意:导出的时候不能直接给exports赋值。
导出数据都是以对象的形式导出的,导入进去的也都是对象。
npm脚本
package.json中的scripts键是用来配置npm命令的,如下:
"script":
"build":"node a.js"
命令配置好以后,就可以在命令行执行配置好的命令:
npm run build
改名其实执行的是:node a.js
scripts中的键都是命令的名称,有4个命令名称比较特殊,在执行的时候,不需要使用run:
npm start === npm run start
npm stop === npm run stop
npm test === npm run test
npm restart === npm run stop && npm run start
命令执行顺序:
如果是并行执行(即同时的平行执行),可以使用 &
符号。例:
npm run script1 & npm run script2
如果是继发执行(即只有前一个任务成功,才执行下一个任务),可以使用 &&
符号。例:
npm run script1 && npm run script2
默认命令:
"start": "node server.js",
"install": "node-gyp rebuild"
在不配置命令的情况下,内置了这样两个命令,前提是有对应的模块。
npm变量:
package.json文件中的所有内容都可以通过环境变量获取到,例:
"name": "test1",
"version": "1.0.0",
"description": "",
"main": "index.js",
"dependencies":
"jquery": "^3.6.0"
,
"devDependencies": ,
"scripts":
"test": "echo \\"Error: no test specified\\" && exit 1"
,
"keywords": ["hello", "world"],
"author": "",
"license": "ISC"
上面的package.json文件中的name属性的值,可以这样获取:
console.log(process.env.npm_package_name);
但正常执行这个文件是没有用的,必须是将执行这个文件的命令配置成脚本命令才有用:
"name": "test1",
"version": "1.0.0",
"description": "",
"main": "index.js",
"dependencies":
"jquery": "^3.6.0"
,
"devDependencies": ,
"scripts":
"test": "echo \\"Error: no test specified\\" && exit 1",
"view":"node view.js"
,
"keywords": ["hello", "world"],
"author": "",
"license": "ISC"
在view.js中的代码:
console.log( process.env ); // 所有环境变量
console.log(process.env.npm_package_name);
执行结果:
这种变量也支持嵌套,例package.json中有如下键和值:
"repository":
"type": "git",
"url": "xxx"
,
获取其中的type键和url键的值:
process.env.npm_package_repository_type
process.env.npm_package_repository_url
package.json中的config键的值,可以被环境变量所覆盖:
"name" : "foo",
"config" : "port" : "8080" ,
"scripts" : "start" : "node server.js"
覆盖命令:
npm config set foo:port 80
再次获取时,值为80。
nvm工具
nvm工具主要用于管理nodejs的版本,可以在一台计算上拥有多个nodejs版本,并轻松切换。可以解决nodejs各个项目中的兼容问题。
在安装的时候,需要先卸载已经安装的nodejs,否则,在安装的时候要选择,现有的nodejs被nvm管理。
下载地址:https://github.com/coreybutler/nvm-windows/releases
安装完成后,在命令执行命令测试是否安装成功:
nvm
nvm命令:
nvm arch # 显示nodejs运行在32位或64位
nvm ls available # 查看所有可下载的版本
nvm list # 查看当前已经安装的nodejs列表 - 简写nvm ls
nvm install <version> [arch] # 安装nodejs,version是指定的nodejs版本,arch可以选择32位或64位
例:
nvm use 版本号 # 切换到指定的版本
nvm use node # 切换到最新版本
anywhere工具
是可以在任何一个文件夹下提供一个web服务器
npm i anywhere -g
使用:在一个文件夹下,执行anywhere即可
默认端口号8000,指定端口号:
anywhere -p 端口号
npx工具
npm从版本5.2开始,自带了npx命令,如果没有自带则需要手动安装:
npm install -g npx
测试:
npx -v
这个命令通常会有一个特殊的应用场景:
当我们需要临时使用一个第三方包运行,而不像将他下载下来的时候,就是用npx来做。
例:
npx anywhere
当前目录中的node_modules文件夹下有这个包的时候,就是用node_modules文件夹下的包,如果没有,就会从远程下载到内存中,然后从内存中运行,当运行完成后,就将内存中下载好的包删除。
nodemon工具
npm i nodemon -g
这是一个全局工具,用法跟node一样,但nodemon可以自动监视文件变化,当文件发生变化会自动重新执行命令。
在自己定义服务器代码的时候,每次修改一点点代码,都需要重新启动服务器,操作比较繁琐,nodemon工具,可以让我们启动一次即可,后面只要文件发生了变化,服务器回自动重启。
nodemon工具的使用方式跟node是一样的。
json-server
依赖一个json文件,快速启动一个web服务器,并生成restful风格的接口(api)
正常情况下,一个接口,提供一种数据的操作,查、修改、删除、新增,数据我们操作的是数据库的数据。现在json-server依赖的这个json文件,其实就是服务器操作的是这个json文件中的数据。
restful风格
路由中不能出现动词,即:get/post/put/delete
路由结尾不能有/
使用-来替换_
建议使用小写字母
使用复数形式
推荐标准状态码:
- 200 ok 服务器返回用户请求的数据
- 201 created 新建或修改操作成功
- 204 not content 删除数据成功
- 400 bad request 用户发出的请求有问题
- 401 unauthoried 表示用户没有认证,无法进行操作
- 403 forbidden 用户访问是被禁止的
- 422 unprocesable entity 当创建一个对象时,发生一个验证错误
- 500 internal server error 服务器内部错误,用户将无法判断发出的请求是否成功
- 503 service unavailable 服务不可用装填,多半是因为服务器问题,例:cpu占用率大…
正常情况下,我们发送get请求,可以查、改、删除…,但是restful风格规范了我们的请求行为,get查。post增。put改。delete删。
正常情况下,get请求携带的参数在请求路径后,从?后面开始的,但是restful风格规范传参的行为:
get /goods - 查询所有
// 以前
get /goods?id=10
// restful
get /goods/10
// 删除以前
get /goods?id=10
// restful
delete /goods/10
状态码:https://www.cnblogs.com/jike1219/p/11421890.html
npm i json-server -g
启动服务器:
json-server json文件
通过postman调试:
yarn工具
yarn跟npm一样,是一个第三方包的管理工具,比起npm,yarn工具更加高效快捷。
通常在下载一些较为复杂的包的时候,多个包之间总会有一些依赖关系,npm下载的时候,使用续发形式下载,也就是同步下载,而yarn是并发形式下载,也就是异步下载,效率更高。例如,我们需要模块A,但是模块A需要依赖模块B,模块B又需要依赖模块C,npm下载的时候是按照顺序:C—>B—>A;yarn下载的时候是并发下载:A和B和C同时下载。
yarn不是一个自带工具,需要手动下载安装,下载地址:https://yarn.bootcss.com/docs/install/#windows-stable 。傻瓜式安装即可。
注意:不要将yarn安装到空格或带中文的文件夹中。
检测安装:
yarn --version
初始化:
yarn init
yarn init -y
下载安装包:
yarn add 包
yarn add 包@版本号
下载参数:
--dev # 将包安装到开发依赖
--peer # 将包安装到同等依赖
--optional # 将包安装到可选依赖
同等依赖:或者叫同伴依赖,用于指定当前包(也就是你写的包)兼容的宿主版本。如何理解呢? 试想一下,我们编写一个gulp的插件,而gulp却有多个主版本,我们只想兼容最新的版本,此时就可以用同等依赖(peerDependencies)来指定
可选依赖:如果有一些依赖包即使安装失败,项目仍然能够运行或者希望npm继续运行,就可以使用optionalDependencies。另外optionalDependencies会覆盖dependencies中的同名依赖包,所以不要在两个地方都写
升级依赖包:
yarn upgrade 包
yarn upgrade 包@版本号
升级没成功。
卸载包:
yarn remove 包
安装全部依赖:
yarn
yarn install
nodejs:0到1的冲刺,毕业小白到公司大佬的逆袭之路,到底学了哪些?(代码片段)
nodejs基础接上一篇:nodejs入门第三方模块就是网上别人已经开发好的模块,我们可以直接拿来借鉴使用,但是需要下载,下载工具使用npm。npm工具下载:npminstall/i包名npmi包名包名...npmi包名@版本号#最新版本... 查看详情
visionpro从小白到大佬,第一章了解工具名称和用途
Visionpro从小白到大佬,第一章了解工具名称和用途目录1、简介2、无非类工具3、Calibration&Fixturing4、Color5、Geometry-Creation6、Geometry-Finding&Fitting7、Geometry-Intersection8、Geometry-Measurement9、Geometry-Measurement10 查看详情
从小白到创业公司ceo,机缘于一个正确的选择!
...个大学同学小张说起,他原本是湖北第二师范学院14级的毕业生,是一个来自湖北荆州偏远山村的农村小伙,因为怀揣着赚大钱的梦想,在上大学的时候他就不停的兼职。边工作边学习,为的就是帮贫穷的家减少经济负担,你很... 查看详情
从渗透测试小白到网络安全大佬成长之路
前言最近看到很多的安全小白在询问如何去学习安全,如何去入手渗透测试等问题。突然有感而发,想起来自己当时从小白一步一步走向黑客大佬的成长之路。随着因特网的发展和网络经济的兴起,越来越多的企业将服务或... 查看详情
我8年的测试岗从业者跟你细谈我是如何从一个测试小白到大佬的转变
...按照软件测试的学习大纲,我总结了一份针对0基础的小白视频教程ÿ 查看详情
5年测试,从小白到主管,在开发的鄙视中野蛮生长
...测试小白还不会代码大家好,我是石头,14届大学毕业生一枚,学得是信息系统管理专业。毕业后,专业对口的工作没找到,却阴差阳错进了一家华为的外包公司。虽然是外包到华为,但对于一个应届生而... 查看详情
读后感:从0到1
...丑化。这本书并不是说从0到1如何成功,而且写了大量的公司案例,总结他们的成功和失败,讨论公司做起来是实力还是运气亦或者是机遇。但是结果无法验证,也就像作者说的,就算时光能够逆转,除非相同的公司,要开很多... 查看详情
学python推荐的10本豆瓣高分书单,小白到大佬,不看后悔一辈子
一,Python编程初学者指南 本书一共12章,每一章都会用一个完整的游戏来演示其中的关键知识点,并通过编写好玩的小软件这种方式来学习编程,引发读者的兴趣,降低学习的难度。每章最后都会... 查看详情
请问大佬们,自己公司的微信小程序能跳转到其他合作公司的微信小程序中吗,怎么跳转啊
这个要看自己的小程序后台有没有支持跳转的功能,如果有的话,就是把要跳转的小程序的APPID填写到自己的小程序里面,同时还有设置以下权限以及跳转路径就可以了。追问大佬,设置什么权限啊参考技术Awx.navigateToMiniProgram(OB... 查看详情
小白0-1学习app开发,从配置到helloword
第一步,注册 选择开发工具有一些教程上会说先创建应用,再选择工具,是使用的控制台创建的https://www.apicloud.com/studio3APICloudStudio3工具的教程https://docs.apicloud.com/Dev-Tools/studio3-visualization-dev-tool-quick-start... 查看详情
从0到1冲刺自动驾驶“最速传说”,云骥智行赶上了好时候?
自动驾驶的竞赛已经进入新阶段,但仍有一批创业公司的潜力尚待发挥。创立于2021年11月,云骥智行是赛道的后来者,却有着不小的野心——“云骥智行致力于打造中国最先进的L4-L5级别自动驾驶通用平台解决方案... 查看详情
编程0基础小白,如何自学python更快、更高效!「方法干货」
参考技术A作为零基础的小白学python,普遍会遇到一个问题:没有找到应用场景。大多数小白在自学一门编程语言时,是没有应用的场景感。说白了,就是不知道学了做什么用,讲不出具体、合理的应用。如果这时候有大佬带着... 查看详情
从开始学习爬虫到真正赚钱只用了一个月——一个普通大专生的逆袭之路(代码片段)
前言我毕业六年了,但与技术和Python相关的工作经验也就两年。今天我想跟大家分享自己转行的故事,希望能够鼓励那些跟我一样的朋友共同前行。我们将会聊到我个人的经历和入行故事,个人的技术成就,讨论... 查看详情
0002嵌入式开发带你从小白到大佬系列之——linux文件系统常用文件操作命令及用户权限
1、熟悉Linux的文件系统结构Linux的文件系统结构其实是一个树形的分层组织结构,如下图:Linux系统目录结构及目录路径:1.1、文件系统层次结构标准Linux是开源的操作系统,各个Linux发行机构都可以按照自己的需求对Linux系统的... 查看详情
python游戏菜单问题,本人python小白,求大佬解决帮一下
'''任务:用元组定义游戏菜单,提示用户输入菜单选择,提示信息为“请输入菜单项对应的数字,1.游戏设置2.选择游戏级别3.我的装备4.我的积分0.退出”,当用户输入数字后,输出相应的菜单项名称,若输入0,则显示... 查看详情
刚进入公司的测试小白
...技术也不够厉害,才刚接触测试这个行业,还是属于测试小白;二:工作没人交接,按照流程的话应该是至少交接一个星期,至少我还能再学点东西,更能了解下这个公司的项目;三:项目没有需求文档,项目经理想到什么就做... 查看详情
推荐一位c++大佬,强悍!
...f0c;专业写代码,热衷于技术分享和职场提升。从大学毕业到现在,待过民企、外企、上市公司,从刚毕业实习进工厂画板子拿烙铁,再到敲键盘复制粘贴写代码,再到现在逐渐摆脱技术思 查看详情
从网瘾少年到网管,再到程序员,看他的逆袭路,哭了……(代码片段)
...都说郎怕入错行,行业对职场人的影响不言而喻。刚毕业的薪资可能跟学历有关,但有的行业天花板很低,直接就决定了你的薪资上限,再努力都很难突破。而IT互联网行业的薪资天花板就高的多。究竟能拿多少... 查看详情