位置: 编程技术 - 正文

nodejs教程之入门(node.js入门)

编辑:rootadmin

推荐整理分享nodejs教程之入门(node.js入门),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:nodejs 入门教程,nodejs基础知识,node.js入门,nodejs快速入门,nodejs快速入门,nodejs基础知识,nodejs快速入门,nodejs 入门教程,内容如对您有帮助,希望把文章链接给更多的朋友!

前言

再不学nodeJs,我们就老了......在HTML5大浪袭来的时候,很多先辈就开始了NodeJs之旅,而那时我还在做服务器端的程序后来转成前端,和梯队的距离已经很大了,因为我会服务器端语言,还干了很久,所以至今才开始学习NodeJs,向完整的前端前进这次学习NodeJs的计划是:① 1-2周学习基础知识② 1周左右开发一个简单项目③ 利用NodeJs开发一套用于移动端调试的工具④ 打包相关(这个可能比较远了)

NodeJs特点

① 异步从文件读取到网络请求,NodeJs皆以异步完成,回调函数占据重要作用,在编程模型上Node是领先的

② 事件回调事件回调让程序变得轻巧,但是具体怎么样还是取决于程序员。但是回调函数在阅读上其实还是有一定难度的

③ 单线程Node是单线程的,如果多线程的话,这门语言水又深了,问几句进程中的通信时很讨厌的,但线程也没有死锁等问题但是性能相关就有问题了,因为不能利用多核;

模块机制/CommonJs

我们原来做服务器端的开发,如果没有很好的组织代码的话,后期维护非常困难,所以才会有什么MVC,什么三层架构而现在前端的业务逻辑逐向后端靠拢,就单页应用来说,已经超过后端的程序逻辑页面view不停的增加会带来js代码量的激增,如何很好的管理我们的前端代码成了一个问题,所以requireJs出现了......PS:尼玛这段和nodeJs有一毛钱关系哇......javascript是没有模块化系统的,于是就有CommonJs的提出,让js具备开发大型应用的基础

模块引用

我们如果要引用一个模块,比如数学计算相关:

var math = require('math');

模块定义

我们如果要定义自己的模块可以这样干

如果此函数在math中定义的话,就能使用了

math.add();

模块标识

nodejs教程之入门(node.js入门)

模块标识就是传递给require的参数,需要为驼峰命名,指向的是一个文件路径,这里和requireJS很类似的

模块实现

Node中模块实现分为两类,一种是系统级别的核心模块,一种是用户编写的文件模块核心模块在编译过程被翻译成了二进制文件,Node进程启动后,一些核心的模块会直接加载进内存(文件定位、编译执行)文件模块需要动态加载,速度相对慢一点但是一旦加载后,那些文件便会被缓存,二次引入时候便会读取缓存文件(编译后的文件)这里扯远一点,我们在使用underscore过程中,会编译Html形成模板函数(他真的只是一个函数),其实这个就可以做缓存在部署项目之前保存编译过后的函数,去掉html模板文件(优化效果不知)

在node中,每个模块都是一个对象:

编译和执行时引入文件模块的最后一个阶段,定位到具体文件后,node会新建一个模块对象,然后根据路径载入并编译每一个编译成功的模块都会将其文件路径作为索引缓存在Module._cache上

每个模块文件都存在require、exports、module三个变量,但是在文件中并未定义(__filename__、__dirname__ 变量也是)其实在编译过程中,Node对javascript文件内容进行了头尾包装(相当于自定义函数传入window)

这样,模块与模块之间做了隔离,不会互相影响,这里和underscore的编译有些类似......

包与NPM

Node组织了自身的核心模块,所以第三方文件模块可以有序的编写和使用,但是在第三方模块中,模块与模块之间仍然散列在各地相互之间不能直接引用,在模块外包和NPM则是将联系建立起来的一种机制PS:很多模块会形成一个包,这个包的概念和java包的概念,才#程序集的概念应该相似

一个包结构解压后会形成几个文件:① package.json 描述文件② bin 可执行二进制目录③ lib javascript代码目录④ doc 文档(尼玛基本没有)⑤ test demo

以上都是CommonJS包的规范的一些东西,但是我们稍微了解一下便可(初学嘛),NPM则需要熟练掌握,借助NPM我们可以熟练安装管理包

安装依赖包

安装依赖包是常用方法:

npm install express执行后就会在当前目录下创建node_modules目录,然后再其下面创建express目录......PS:express是NodeJs上流行的web开发框架,帮助我们快速开发一个web应用安装结束后就可调用了:

结语

这段简单结束,后面我们项目实战过程逐步深化

nodejs教程之异步I/O 前言在我映像中,异步最早出现与ajax,当时我还在搞.net,然后.net居然出了一个异步的控件......虽然我最后知道了他不是异步的......然后,前端异步用

nodejs教程之环境安装及运行 让nodeJS跑起来第一步当然是安装nodeJS环境了,现在windows安装nodeJS比较快了,直接下载即可:

nodejs教程之制作一个简单的文章发布系统 前言我们今天就来做一个简单的新闻发布系统,系统第一阶段不需要太难,主要有以下功能①新闻类型管理②新闻管理(具有图片上传功能)③新闻浏

标签: node.js入门

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

上一篇:node.js使用npm 安装插件时提示install Error: ENOENT报错的解决方法(node.js的安装方法)

下一篇:nodejs教程之异步I/O(nodejs异步编程及原理)

  • 一般纳税人什么条件
  • 一般纳税人开普票和专票有什么区别
  • 金蝶k3如何设置凭证保存自动新增
  • 期初是什么
  • 应付职工薪酬为什么不属于金融负债
  • 资产负债表本月期末余额怎么填
  • 现代服务业加计抵减政策适用范围
  • 企业承担的员工在职培训成本包括
  • 增值税普票没有税率怎么回事
  • 职工福利基金提取规定
  • 从公司账户转给个人账户取出来发给员工做过节费
  • 试车要给钱吗
  • 退税详细教程
  • 小微企业分公司 企业所得税优惠
  • 北京增值税纳税申报表在哪里打印
  • 公司帮员工买的保险
  • 零余额账户用款额度年末转入什么科目
  • 盘亏机器设备会计分录
  • 周转材料盘点报告单
  • 成本核算的基本方法及适用范围
  • 上年度少计提的税金及附加
  • 开发票时已交的税金怎么做帐?
  • 企业跨年度的收入退回应该如何进行会计处理?
  • 安置房项目需要环评吗
  • 营改增后哪些费用可以抵扣
  • 一个非常好看的中秋礼物怎么做
  • 彻底清理缓存
  • 如何解决焦虑
  • crontab不执行的原因和解决方案
  • 补缴免抵退
  • 微信小程序实现支付功能
  • mysql刷新数据
  • php使用函数限制字符串长度和格式
  • php高级程序招聘
  • phpcms二次开发教程
  • 进口关税和增值税怎么做账
  • node.js入门教程
  • 工资预提和计提的区别
  • 捐赠支出怎么抵税
  • 保险公司给员工奖励是违法的吗
  • 电算化会计档案论文答辩自述稿
  • sqlserversa用户登录失败
  • 基本户收到款不入账
  • 周转材料低值易耗品五五摊销法
  • 进口代理费取费标准
  • 固定资产报废会计
  • 邮局的定额发票能报销吗
  • 新办企业在建期间账务处理
  • 营业账簿印花税怎么申报
  • 物流公司账务处理流程及方法
  • 劳务报酬与经营所得
  • 财税2009年87号文废止
  • 中国电子口岸企业法人卡
  • 如何设置固定资产二级联动下拉菜单
  • mac查看下载
  • win101607升级1909
  • linux命令su-
  • win7系统打印机共享给win10
  • win8删文件需要权限怎么弄
  • win10更新提示错误
  • 二分法查找 js
  • php消息队列面试题及答案
  • 从《AndEngine游戏开发实践指南》开始,学习AndEngine引擎
  • android mark
  • linux shell打开文件
  • perl \w
  • netcfghlp怎么安装
  • mongoose怎么用
  • Python类的继承动物类
  • XML、HTML、CSS与JS的区别整理
  • python生成docx
  • python中else语句
  • jquery教程实例
  • 基于unity的游戏开发
  • 用JObj实现的渐变效果
  • 代收代付税务条件
  • 江苏国税电子税局
  • 变更主管税务机关需要注销吗
  • 互城通怎么用微信充值
  • 境外所得税额扣除的计算
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设