zoukankan      html  css  js  c++  java
  • 手写expres

    // const express = require('express')
    // const app = express()
    // app.get('/',function(req,res){
    //     res.end('我是根目录')
    // })
    // app.get('/good',function(req,res){
    //     res.end('oh you are good')
    // })
    // app.listen('40087',function(){
    //     console.log('正在监听40087')
    // })
    新建一个js模仿express框架,去完成一个自己的express框架,比如下面的这个js文件我们暂且命名为self.js
    const myExpress = require('./self封装的express.js')
    const app = myExpress()
    app.get('/',function(req,res){
        res.end('我是根目录')
    })
    app.get('/good',function(req,res){
        res.end('oh you are good')
    })
    app.listen('40087',function(){
        console.log('正在监听40087')
    })
    新建一个js文件《self封装的express.js》
     
    const http = require('http')
    const url = require('url')
    let routes = []
    class myExpress{
        get(path,handle){
            routes.push({path,handle})
        }
        listen(){
            const server = http.createServer(function(req,res){
                const {pathname} = url.parse(req.url)
                console.log(pathname)
                routes.find((p)=>{
                    return p.path == pathname
                }).handle(req,res)
            })
            server.listen(...arguments)
        }
    }
    module.exports = function(){
        return new myExpress()
    }
    其实这里面我们用到一个发布订阅模式,首先利用get方法将所有的接口把这些接口还有回调函数push到数组中,构造函数提供了一个listen方法暴漏在外面,我们在app.listen()调用的时候,我们就会将数组里面的回调执行(如果接口,方法对上的话),其实这里面就是一个发布订阅模式。
     
     
     
     
     
     
  • 相关阅读:
    Spring 09 : AOP实例
    Spring08 AOP概念
    Spring 07 : 动态代理
    Spring06 Spring+Junit
    Spring05 : 基于注解的IOC
    Spring03 : 依赖注入
    jupyter修改python核(使用不同的python虚拟环境)
    线性代数的本质——引入几何视角
    图像的去雾与加雾
    从MATLAB看一个IDE应该具有的素质
  • 原文地址:https://www.cnblogs.com/MDGE/p/12541189.html
Copyright © 2011-2022 走看看