当前位置: 首页 > news >正文

手机网站前端设计全国工商信息公示系统

手机网站前端设计,全国工商信息公示系统,做结构图的网站,免费生成网址上一节实现 express 的请求处理#xff0c;这一节来进行实现 express 的优化处理 让 layer 提供 match 方法去匹配 pathname#xff0c;方便拓展让 layer 提供 handle_request 方法#xff0c;方便拓展利用第三方库 methods 批量生成方法性能优化问题 进行路由懒加载#…上一节实现 express 的请求处理这一节来进行实现 express 的优化处理 让 layer 提供 match 方法去匹配 pathname方便拓展让 layer 提供 handle_request 方法方便拓展利用第三方库 methods 批量生成方法性能优化问题 进行路由懒加载当进行 get/post... 请求时或者 listen 时才加载 routelayer 进行加速匹配在 layer 层判断是否请求方法在 route 里有 methods 库地址https://www.npmjs.com/package/methods [acl, bind, checkout,connect, copy, delete,get, head, link,lock, m-search, merge,mkactivity, mkcalendar, mkcol,move, notify, options,patch, post, pri,propfind, proppatch, purge,put, rebind, report,search, source, subscribe,trace, unbind, unlink,unlock, unsubscribe ]批量生成方法测试 demo 如下 const express require(./kaimo-express); const app express();app.get(/, (req, res, next) {res.end(get okk end); }); app.post(/, (req, res, next) {res.end(post okk end); });app.listen(3000, () {console.log(server start 3000);console.log(在线访问地址http://localhost:3000/); });控制台执行下面命令 curl -v -X POST http://localhost:3000/layer 进行加速匹配 demo const express require(./kaimo-express); const app express();app.post(/, (req, res, next) {res.end(post okk end); }); app.put(/, (req, res, next) {res.end(put okk end); }); app.delete(/, (req, res, next) {res.end(delete okk end); }); app.options(/, (req, res, next) {res.end(delete okk end); });app.listen(3000, () {console.log(server start 3000);console.log(在线访问地址http://localhost:3000/); });然后去访问http://localhost:3000/可以看到没有优化的时候会请求这些方法 优化之后可以看到就没有请求了 优化的代码如下 application.js const http require(http); const Router require(./router); const methods require(methods); console.log(methods-----, methods);function Application() {}// 调用此方法才开始创建不是创建应用时直接装载路由 Application.prototype.lazy_route function () {if (!this._router) {this._router new Router();} };methods.forEach((method) {Application.prototype[method] function (path, ...handlers) {this.lazy_route();this._router[method](path, handlers);}; });Application.prototype.listen function () {const server http.createServer((req, res) {function done() {res.end(kaimo-express Cannot ${req.method} ${req.url});}this.lazy_route();this._router.handle(req, res, done);});server.listen(...arguments); };module.exports Application;router/index.js const url require(url); const Route require(./route); const Layer require(./layer); const methods require(methods);function Router() {// 维护所有的路由this.stack []; }Router.prototype.route function (path) {// 产生 routelet route new Route();// 产生 layer 让 layer 跟 route 进行关联let layer new Layer(path, route.dispatch.bind(route));// 每个路由都具备一个 route 属性稍后路径匹配到后会调用 route 中的每一层layer.route route;// 把 layer 放到路由的栈中this.stack.push(layer);return route; };methods.forEach((method) {Router.prototype[method] function (path, handlers) {// 1.用户调用 method 时需要保存成一个 layer 当道栈中// 2.产生一个 Route 实例和当前的 layer 创造关系// 3.要将 route 的 dispatch 方法存到 layer 上let route this.route(path);// 让 route 记录用户传入的 handler 并且标记这个 handler 是什么方法route[method](handlers);}; });Router.prototype.handle function (req, res, out) {console.log(请求到了);// 需要取出路由系统中 Router 存放的 layer 依次执行const { pathname } url.parse(req.url);let idx 0;let next () {// 遍历完后没有找到就直接走出路由系统if (idx this.stack.length) return out();let layer this.stack[idx];// 需要判断 layer 上的 path 和当前请求路由是否一致一致就执行 dispatch 方法if (layer.match(pathname)) {// 将遍历路由系统中下一层的方法传入// 加速匹配如果用户注册过这个类型的方法在去执行if (layer.route.methods[req.method.toLowerCase()]) {layer.handle_request(req, res, next);} else {next();}} else {next();}};next(); };module.exports Router;route.js const Layer require(./layer); const methods require(methods);function Route() {this.stack [];// 用来描述内部存过哪些方法this.methods {}; }Route.prototype.dispatch function (req, res, out) {// 稍后调用此方法时回去栈中拿出对应的 handler 依次执行let idx 0;console.log(this.stack-----, this.stack);let next () {// 遍历完后没有找到就直接走出路由系统if (idx this.stack.length) return out();let layer this.stack[idx];console.log(dispatch-----, layer.method);if (layer.method req.method.toLowerCase()) {layer.handle_request(req, res, next);} else {next();}};next(); }; methods.forEach((method) {Route.prototype[method] function (handlers) {console.log(handlers-----, handlers);handlers.forEach((handler) {// 这里的路径没有意义let layer new Layer(/, handler);layer.method method;// 做个映射表this.methods[method] true;this.stack.push(layer);});}; });module.exports Route;layer.js function Layer(path, handler) {this.path path;this.handler handler; }Layer.prototype.match function (pathname) {return this.path pathname; }; Layer.prototype.handle_request function (req, res, next) {this.handler(req, res, next); }; module.exports Layer;
http://www.hkea.cn/news/14389759/

相关文章:

  • 阿里云虚拟主机可以做几个网站建设银行企业网站失败
  • php网站项目wordpress添加文件
  • 濮阳网站建设费用湖南网站营销优化开发
  • 网站超级外链如何建一个个人网站
  • wordpress分享视频网站建设银行梅州分行网站
  • 天津工程建设协会网站音乐网站开发需要什么语言工具
  • 做网站有回扣拿吗网站的代码在哪里设置
  • 个人介绍微电影网站模板免费制作企业微商城
  • 宁德北京网站建设成都网站推广公司排名
  • 如何做网站demowordpress官方模版
  • 网站开发市场哪个浏览器看黄页最快夸克浏览器
  • 成都网站定制中心连云港做网站制作首选公司
  • 百度搜索这个网站为什么这么差小说网站建设方案书ppt模板
  • 山东电力建设第一工程公司网站鹤壁市城乡一体化示范区范围
  • 常州网站建设平台网页建立站点
  • 虾皮网站有的做吗系统开发毕业设计
  • 做外卖那些网站好电子商务网站建设与管理英文
  • 网站正在建设中换句话表达今天实时热搜榜排名
  • 做一手房用什么网站wordpress文章对齐
  • 怎么把网站设置为信任网站51免费模板网
  • 微网站如何做推广图片设计制作网站
  • 网站联盟有哪些wordpress 网盘
  • 外包公司做的网站推广普通话手抄报内容
  • 坑人网站怎么做兰州市城乡建设厅网站
  • 深圳公司网站优质视频素材网站
  • dnf做汉堡怎么玩间网站南昌建站系统外包
  • html购物网站网站开发教程H5
  • 国外免费网站网络营销的本质
  • 手机网站开发技术pdf济南网站建设与优化
  • 重庆企业的网站建设做国际贸易网站要什么条件