Node.js学习笔记

Node.js核心与实践

1 Node的作用和应用

  • 脱离浏览器运行JS
  • 后台API编写
  • 前端工程化的工具webpack、gulp、npm依赖于node
  • 负责中间层读写(性能好、异步IO的特性,适合处理高并发的请求;处理数据;安全性)

2 Node的优势

  • 便于前端开发入门
  • 性能高
  • 利于前端代码整合

3 NPM包管理

npm概念:node package managemet,用于管理第三方的插件、模块、库

  • 为什么要用npm?

    不用npm用的是script引入,不容易管理;

    而使用npm,可以用package.json用于管理依赖

  • 如何生成package.json?

    在当前文件夹 npm init 初始化

  • 如何安装第三方的包?

    在当前文件夹 npm install(简写 i) 第三方包 安装完后会自动添加到依赖中

  • 如何删除第三方的包?

    在当前文件夹 npm uninstall(简写 un) 第三方包

  • 如何使用cnpm?

    npm install -g cnpm --registry=https://registry.npm.taobao.org,后续和npm使用方法一样

4 Node的模块

  • 全局模块

    随时随地都能访问,不需要引用process.env (env环境变量)process.argv (打印的命令,加参数等等)

  • 系统模块

    定义需要require(),但不需要单独下载系统内置

    path:用于处理文件路径和目录路径的工具

    let path=require(‘path’) path.dirname() path.basename() path.extname()

    fs:用于文件读写 fs.readFile() fs.writeFile()

  • 自定义模块

    require自己封装的模块

    • exports

    ​ exports.a=1 //在自定义模块里定义

    ​ require(’./mod’) //引入模块,去路径里面找;路径里没有就去node_modules里面找;再去node安装目录里找

    • module

    ​ 批量导出

    ​ module.exports=fucnction/class(){}

    • require
  • HTTP模块

    let http=require('http')
    http.createServer((request,response)=>{
    console.log(req.url)
    fs.readFile(`./${req.url}`,(err,data)=>{
    if(err){
    res.writeHead(404)
    res.end('404 not found')
    }else{
    res.end(data)
    }})
    res.write('index')
    res.end()
    }).listen(端口)

    然后再访问一下这个端口

5 Node中的数据交互

  • GET请求(head)

​ 获取数据,数据是放在url里面传输,容量小<32k

let http=require('http')
let url=require('url')  //URL模块
http.createServer((req,res)=>{
let {pathname,query}=url.parse(req.url,true)
console.log(pathname,query)
}).listen(端口)
<form action="http://localhost:8888/aaa(url)" method="GET">

输入表单内容后服务器返回

aaa?username=milo&password=123456

  • POST请求(body)

​ 数据是放在body里面传输,容量小<2G

http.createServer((req,res)=>{
let result=[]
req.on('data',buffer=>{
result.push(buffer)
})
req.on('end',()=>{
let data=Buffer.concat(result).toString() //concat连接多个数组
console.log(querystring.parse(data))   //parse将数据转化为json对象,解析
})
console.log(pathname,query)
}).listen(端口)
 <form action="http://localhost:8888/aaa(url)" method="POST">

6 接口

接口概念: 不同功能层间的通信规则

参数:如username、password

返回值:{

err:1,

msg:“密码”

}

7 简单实现登录功能

const http=require('http')
const url=require('url')
const querystring=require('querystring')
let user={
    admin:123456
}
http.createServer((req,res)=>{
    let path,get,post
    if(req.method=='GET'){
        let{pathname,query}=url.parse(req.url,true)
        path=pathname,
        get=query
        complete()
    }else if(req.method=='POST'){
        let result=[]
        req.on('data',buffer=>{
        result.push(buffer)
    })
    req.on('end',()=>{
        post=querystring.parse(Buffer.concat(result).toString())
    })
        complete()
}

    function complete(){
        if(path=='/login'){
            let {username,password}=get
            if(!user[username]){
                res.end(JSON.stringify({
                    err:1,
                    msg:"用户名不存在"
                }))
            }else if(user[username]!=password){
                res.end(JSON.stringify({
                    err:1,
                    msg:"密码错误"
                }))
            }else{
                res.end(JSON.stringify({
                    err:0,
                    msg:"登录成功"
                }))
            }
        }
    }
}).listen(8080)
【直流微电网】径向直流微电网的状态空间建模与线性化:一种耦合DC-DC变换器状态空间平均模型的方法 (Matlab代码实现)内容概要:本文介绍了径向直流微电网的状态空间建模与线性化方法,重点提出了一种基于耦合DC-DC变换器状态空间平均模型的建模策略。该方法通过对系统中多个相互耦合的DC-DC变换器进行统一建模,构建出整个微电网的集中状态空间模型,并在此基础上实施线性化处理,便于后续的小信号分析与稳定性研究。文中详细阐述了建模过程中的关键步骤,包括电路拓扑分析、状态变量选取、平均化处理以及雅可比矩阵的推导,最终通过Matlab代码实现模型仿真验证,展示了该方法在动态响应分析和控制器设计中的有效性。; 适合人群:具备电力电子、自动控制理论基础,熟悉Matlab/Simulink仿真工具,从事微电网、新能源系统建模与控制研究的研究生、科研人员及工程技术人员。; 使用场景及目标:①掌握直流微电网中多变换器系统的统一建模方法;②理解状态空间平均法在非线性电力电子系统中的应用;③实现系统线性化并用于稳定性分析与控制器设计;④通过Matlab代码复现和扩展模型,服务于科研仿真与教学实践。; 阅读建议:建议读者结合Matlab代码逐步理解建模流程,重点关注状态变量的选择与平均化处理的数学推导,同时可尝试修改系统参数或拓扑结构以加深对模型通用性和适应性的理解。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值