位置: IT常识 - 正文

Node.js | 从前端到全栈的必经之路(nodejs如何与前端交互)

编辑:rootadmin
Node.js | 从前端到全栈的必经之路

推荐整理分享Node.js | 从前端到全栈的必经之路(nodejs如何与前端交互),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:前端node如何结合,node.js前后端交互,node.js前端还是后端,前端node如何结合,node.js在前端开发中的作用,nodejs做前端,node.js在前端开发中的作用,前端使用node.js,内容如对您有帮助,希望把文章链接给更多的朋友!

🧑‍💼 个人简介:即将大三的学生,一个不甘平庸的平凡人🍬 🖥️ NodeJS专栏:Node.js从入门到精通 🖥️ 博主的前端之路:前端之行,任重道远(来自大三学长的万字自述) 🖥️ TypeScript知识总结:TypeScript从入门到精通(十万字超详细知识点总结) 👉 你的一键三连是我更新的最大动力❤️!

文章目录前言一、什么是NodeNode.js的由来Node.js的特性二、浏览器环境与Node环境对比三、搭建Node环境四、体验Node模块化开发CommonJS方式ES Modules方式结语前言

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

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

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

博主的Node系列专栏开始更新了,赶快点击订阅专栏来追更吧!

一、什么是Node

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

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

学习Node我们可以非常平滑的过渡到全栈开发,并且如果你之前学习过Vue,React等前端框架或者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月,经过十几年的发展,它已经成为前端中顶梁柱的存在,就算你不需要它进行服务端开发,它也存在于你开发过程中的方方面面,如前面提到的Vue,React,Webpack

Node.js的特性

Node.js贯穿于客户端(如Vue这类框架的底层依赖)和服务端(如后端开发)

Node.js的语法完全就是javascript和ES6的语法

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环境Node.js | 从前端到全栈的必经之路(nodejs如何与前端交互)

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

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

推荐下载这个长期维护的稳定版本,下载完成后一路Next安装即可

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

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

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

四、体验Node模块化开发

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

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

CommonJS方式

Node默认是CommonJS方式:

// index.jsconst 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.jsconst 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不迷路!

Node系列专栏开始更新了,赶快点击订阅专栏来追更吧!

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

本文链接地址:https://www.jiuchutong.com/zhishi/299636.html 转载请保留说明!

上一篇:【Spring】一文带你吃透AOP面向切面编程技术(上篇)(spring的文章)

下一篇:【目标检测】YOLOv5模型从大变小,发生了什么?(目标检测yolo)

  • 快手怎么关闭浏览设置(快手怎么关闭浏览记录不让别人看到)

    快手怎么关闭浏览设置(快手怎么关闭浏览记录不让别人看到)

  • 企业微信联系人那一栏怎么删除(企业微信联系人怎么关闭)

    企业微信联系人那一栏怎么删除(企业微信联系人怎么关闭)

  • win7系统360浏览器提示证书风险怎么解决(win7系统360浏览器自动打开怎么关闭)

    win7系统360浏览器提示证书风险怎么解决(win7系统360浏览器自动打开怎么关闭)

  • 荣耀x10和红米10x的区别有哪些(荣耀X10和红米note11TPor哪个好)

    荣耀x10和红米10x的区别有哪些(荣耀X10和红米note11TPor哪个好)

  • 华为nova4能装联通的卡吗(华为nova4可以直接连接usb吗)

    华为nova4能装联通的卡吗(华为nova4可以直接连接usb吗)

  • 苹果6s电池容量(苹果6s电池容量可以加大吗)

    苹果6s电池容量(苹果6s电池容量可以加大吗)

  • cad无法复制到剪贴板(cad无法复制到剪切板怎回事)

    cad无法复制到剪贴板(cad无法复制到剪切板怎回事)

  • 相册完全删除的照片怎么找回(相册完全删除的照片在哪)

    相册完全删除的照片怎么找回(相册完全删除的照片在哪)

  • 拼多多发起拼单不想要了怎么办(拼多多发起拼单和参与拼单的区别)

    拼多多发起拼单不想要了怎么办(拼多多发起拼单和参与拼单的区别)

  • 高德gps信号弱怎么办(高德gps信号弱怎么设置)

    高德gps信号弱怎么办(高德gps信号弱怎么设置)

  • 爱剪辑可以合并视频吗(爱剪辑可以合并音频吗)

    爱剪辑可以合并视频吗(爱剪辑可以合并音频吗)

  • 苹果x安兔兔跑分多少正常(iphonex安兔兔能跑多少分)

    苹果x安兔兔跑分多少正常(iphonex安兔兔能跑多少分)

  • 路由器dmz主机是什么(路由设置dmz主机)

    路由器dmz主机是什么(路由设置dmz主机)

  • mate30新机有贴膜吗(华为mate30新机有贴膜吗)

    mate30新机有贴膜吗(华为mate30新机有贴膜吗)

  • 小米cc9e手机自带快充吗(小米cc9手机自动开关机怎么设置)

    小米cc9e手机自带快充吗(小米cc9手机自动开关机怎么设置)

  • word如何取消双页编辑(word如何取消双行合一)

    word如何取消双页编辑(word如何取消双行合一)

  • 手机被标记房产中介怎么取消(手机被标记中介房产怎么取消)

    手机被标记房产中介怎么取消(手机被标记中介房产怎么取消)

  • 手机短信没声音是怎么回事(oppo手机短信没有声音怎么设置)

    手机短信没声音是怎么回事(oppo手机短信没有声音怎么设置)

  • iphone11pro怎么显示农历(iphone11pro怎么显示网速)

    iphone11pro怎么显示农历(iphone11pro怎么显示网速)

  • vivo流量提示如何取消(vivox60流量显示)

    vivo流量提示如何取消(vivox60流量显示)

  • 快手怎么举报正在直播(快手上如何举报人)

    快手怎么举报正在直播(快手上如何举报人)

  • 荣耀v20如何正确充电(荣耀v20如何正确关机)

    荣耀v20如何正确充电(荣耀v20如何正确关机)

  • windows照片查看器(windows照片查看器下载)

    windows照片查看器(windows照片查看器下载)

  • 淘宝怎么评价(淘宝怎么评价好评)

    淘宝怎么评价(淘宝怎么评价好评)

  • 优酷悬浮窗播放怎么弄(优酷 悬浮窗)

    优酷悬浮窗播放怎么弄(优酷 悬浮窗)

  • 微软阻止第三方下载 Windows 镜像?(microsoft阻止应用启动)

    微软阻止第三方下载 Windows 镜像?(microsoft阻止应用启动)

  • 笔记本电池保养(笔记本电池保养注意事项)

    笔记本电池保养(笔记本电池保养注意事项)

  • 小企业会计准则适用于哪些企业
  • 职工福利费会计凭证
  • 小规模纳税人做账要做增值税吗
  • 小规模增值税的三个附加税计算公式是什么
  • 办公室提前退租未摊完的装修费如何处理
  • 收到以前年度的货款分录
  • 子公司注销资金还母公司冲实收资本吗
  • 企业购买的雇主责任险
  • 房屋改造工程怎么计入固定资产
  • 自建厂房可以不办理房产证吗
  • 投资办厂协议
  • 汇总缴纳增值税附加税如何缴纳
  • 劳务报酬个人所得税怎么计算
  • 什么情况下可以收取现金
  • 维修费和配件能抵税吗
  • 收汇结汇的账务处理
  • 公司注销有哪些原因
  • 研发费用的
  • 盘盈入库和其他入库
  • 网上申报城建税及附加怎么操作
  • 个人取得的哪些收入属于经营所得
  • 年末提取盈余公积的会计分录怎么写
  • 查账征收改为核定征收需要什么资料
  • 在windows7的
  • 王者荣耀进不去怎么回事最新
  • 土地用于自建项目怎么办
  • linux -e -f
  • 关闭win10系统更新有什么后果
  • msgdlg.exe是什么意思
  • php字符串赋值
  • 工程结算和决算一样吗
  • 前端解决浏览器跨域问题
  • php中\n
  • 商业银行流动性风险监管指标
  • 民办非企业单位登记管理暂行条例
  • 4s店试驾车出售收益为什么不能做主营业务收入
  • vue 富文本编辑框
  • 外经证过期没有注销罚款多少
  • 小规模能取得专用发票吗
  • 住宿费当月抵扣吗
  • 织梦怎么新建页面
  • 中国移动发票抬头开错了可以重开吗
  • access不能打开数据库
  • mysql编程一般步骤
  • 收款金额比开票金额多怎么处理
  • 资产减值损失影响企业利润总额吗
  • 所得税怎么收取
  • 营利性幼儿园是什么意思
  • 财务管理税后利息费用都包含什么
  • 新股东入股的账务处理
  • 销项税多做了怎么冲
  • 预付账款可以开发票吗
  • 企业退款给个人多久到账
  • 待抵扣进项税额什么意思
  • 机器设备一般折旧几年
  • 公司缴纳印花税如何缴纳
  • 企业的利润怎么提出来
  • 中国电子口岸企业法人卡
  • 企业会计做账教程
  • 开办费如何摊销成本
  • linux下mysql5.7.19(tar.gz)安装图文教程
  • win8 win8.1
  • kb5003169安装失败
  • centos 安装方法
  • win8.1中文版下载
  • windows关机音乐
  • 博通网卡驱动win7
  • windows10玩游戏卡吗
  • win10怎么设置扩展屏
  • shell脚本tr
  • Unity3D游戏开发标准教程吴亚峰于复兴人民邮电出版社
  • 批处理修改文件后缀名
  • python之virtualenv的简单使用方法(必看篇)
  • centos安装完成后桌面没有图标
  • js判断函数
  • [置顶]电影名字《收件人不详》
  • 百旺金赋天津客服电话
  • 社保ukey怎么使用
  • 税务局科员是什么职业
  • 徐州交社保有户口限制吗
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设