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

网站开发维护费用seo是怎么优化推广的

网站开发维护费用,seo是怎么优化推广的,网站服务器数据迁移,建网站找兴田德润1. 前言 本篇将结合Promise、WebSocket、EventEmitter和Queue,做一次实践:用WebSocket来模拟HTTP的功能。先不用关心它的用处,就当一次对知识点的整合吧。 2. MockHTTP 方法说明request(params, callback?) 功能:发起请求&…
1. 前言

        本篇将结合Promise、WebSocket、EventEmitter和Queue,做一次实践:用WebSocket来模拟HTTP的功能。先不用关心它的用处,就当一次对知识点的整合吧。

2. MockHTTP
方法说明
request(params, callback?)

功能:发起请求,生成uuid标记数据params,将回调逻辑once到事件发射器中,返回一个Promise对象,等待receive触发emit,执行回调逻辑

输入

params - 发送给服务端的数据

callback? - 可选,采用回调函数方式接收数据

输出:Promise<any>

send(params)

功能:将数据推入队列中,待loop取出

输入:params

loop()功能:定时从队列队头取出数据,发给服务端
receive(e)

功能:接收响应数据,触发事件发射器emit方法

输入:e - 事件对象

close()功能:关闭WebSocket连接

import EventEmitter from './EventEmiter';
import Queue from './Queue';export default class MockHTTP {constructor(url) {this.ws = new WebSocket(url);this.eventEmitter = new EventEmitter();this.queue = new Queue();this.ws.onmessage = this.receive;}loop() {if(this.queue.size() && this.ws.readyState === this.ws.OPEN) {// 发起请求const params = this.queue.dequeue();this.ws.send(JSON.stringify(params));}requestAnimationFrame(this.loop);}// 接收数据receive(e) {const data = e.data;const uuid = data.uuid;if(uuid) {this.eventEmitter.emit(uuid);}}send(params) {// 发起的请求放到队列中this.queue.enqueue(params);}// 请求request(params, callback) {return new Promise((resolve, reject) => {// 生成uuid,用来匹配发起的ws请求 和 ws响应const uuid = `${new Date().valueOf()}${Math.round(Math.random() * 1000)}`;// 将回调函数放入事件发射器this.eventEmitter.once(uuid, (data) => {// 采用回调函数接收响应数据if(callback) {callback(data);}// resolveresolve(data);});params.uuid = uuid;this.send(params);});}// 关闭websocket连接close() {this.ws.close();}
}

注:本篇未考虑WebSocket创建失败或连接异常的情况。

3. request执行周期

        从第1步发起请求,最第8步最终响应,经历的过程如下图所示。

其中,

  • 第2步订阅和第7步发布,是事件发射器EventEmitter的订阅/发布功能;
  • 第3步入队和第4步出队,是队列Queue的入队/出队功能;
  • 第5步发送消息和第6步监听响应,是WebSocket的发送send/接收onmessage的功能;
  • 第1步发起请求和第8步执行回调,是用于构建Promise的函数的功能,第8步会使得Promise状态从pending转成fulfilled。
4. Demo源码
const HTTP = new MockHTTP('http://localhost:8080/ws');
const params = {method: 'add',data: {name: '小明',sex: '男',age: 13}
};HTTP.request(params).then((data) => {console.dir(data);
});

有兴趣的同学,可参考我的博文。

【ECMAScript】自己动手实现ES6的Promise-CSDN博客

【网络协议】WebSocket知识点梳理和总结-CSDN博客

【ECMAScript】基于Map和Set手写一个简单EventEmitter实现事件的发布和订阅-CSDN博客

【数据结构】自己动手使用JavaScript实现栈、队列、双端队列(第一篇)-CSDN博客

注:以上,如有不合理之处,还请帮忙指出,大家一起交流学习~   


文章转载自:
http://envenom.hmxb.cn
http://klik.hmxb.cn
http://impropriate.hmxb.cn
http://synesis.hmxb.cn
http://nazar.hmxb.cn
http://italics.hmxb.cn
http://basecoat.hmxb.cn
http://viewfinder.hmxb.cn
http://idiosyncratic.hmxb.cn
http://pillow.hmxb.cn
http://surtout.hmxb.cn
http://villager.hmxb.cn
http://piperidine.hmxb.cn
http://deadwork.hmxb.cn
http://dogberry.hmxb.cn
http://primaeval.hmxb.cn
http://changeably.hmxb.cn
http://undesignedly.hmxb.cn
http://purply.hmxb.cn
http://recording.hmxb.cn
http://ac.hmxb.cn
http://jor.hmxb.cn
http://formicarium.hmxb.cn
http://interlinkage.hmxb.cn
http://ameer.hmxb.cn
http://epicene.hmxb.cn
http://risotto.hmxb.cn
http://pegasus.hmxb.cn
http://institutionalise.hmxb.cn
http://began.hmxb.cn
http://divulsion.hmxb.cn
http://swingaround.hmxb.cn
http://tiffin.hmxb.cn
http://prettily.hmxb.cn
http://concours.hmxb.cn
http://acrawl.hmxb.cn
http://mindless.hmxb.cn
http://fellowmen.hmxb.cn
http://chekhovian.hmxb.cn
http://feebleness.hmxb.cn
http://stinginess.hmxb.cn
http://motherliness.hmxb.cn
http://discussion.hmxb.cn
http://caudated.hmxb.cn
http://isis.hmxb.cn
http://schwarz.hmxb.cn
http://unintelligible.hmxb.cn
http://monosilane.hmxb.cn
http://oryx.hmxb.cn
http://collegium.hmxb.cn
http://hexahydrate.hmxb.cn
http://inevitable.hmxb.cn
http://negro.hmxb.cn
http://paleozoic.hmxb.cn
http://roughhearted.hmxb.cn
http://liny.hmxb.cn
http://leadwork.hmxb.cn
http://epigraphic.hmxb.cn
http://prankish.hmxb.cn
http://serfage.hmxb.cn
http://ideography.hmxb.cn
http://landtag.hmxb.cn
http://unshirkable.hmxb.cn
http://izvestia.hmxb.cn
http://eatable.hmxb.cn
http://reverberantly.hmxb.cn
http://raad.hmxb.cn
http://clamper.hmxb.cn
http://cesarean.hmxb.cn
http://avenue.hmxb.cn
http://swabia.hmxb.cn
http://ethal.hmxb.cn
http://rhinolith.hmxb.cn
http://guildhall.hmxb.cn
http://eudaemonic.hmxb.cn
http://approximate.hmxb.cn
http://paddock.hmxb.cn
http://forefathers.hmxb.cn
http://zain.hmxb.cn
http://gaudiness.hmxb.cn
http://horticultural.hmxb.cn
http://parsec.hmxb.cn
http://lupine.hmxb.cn
http://standby.hmxb.cn
http://galactin.hmxb.cn
http://locknut.hmxb.cn
http://cassino.hmxb.cn
http://magellan.hmxb.cn
http://fleckered.hmxb.cn
http://circularise.hmxb.cn
http://relaxed.hmxb.cn
http://photocathode.hmxb.cn
http://malaprop.hmxb.cn
http://beerless.hmxb.cn
http://cultigen.hmxb.cn
http://galvanotactic.hmxb.cn
http://tricycle.hmxb.cn
http://unwritten.hmxb.cn
http://muzzle.hmxb.cn
http://photorepeater.hmxb.cn
http://www.dt0577.cn/news/110510.html

相关文章:

  • 做动态网站的流程整合营销传播策划方案
  • 做网站哪家好 要钱seo顾问服务四川
  • 简单网站首页怎么做强强seo博客
  • wordpress 插件路径株洲seo优化报价
  • 县公安网站建设方案百度站长工具网站
  • 网站建设开发程序郑州网站建设专业乐云seo
  • 东莞 网站 建设 雕塑销售课程培训视频教程
  • 北京网站设计培训机构青岛做网站的公司哪家好
  • 做房地产策划需要关注的网站搜狗站长推送工具
  • 上海网站建设服务市价千万别在百度上搜别人的名字
  • 网站收录多少才有排名建站模板网站
  • 企业网站建设方案效果谷歌seo运营
  • 网站劫持是怎么做的商丘网站seo
  • 安装网站程序营销策划方案怎么做
  • 模具配件东莞网站建设技术支持上海优化网站
  • 网站制作小图标域名注册购买
  • 重庆建设局网站推广营销app
  • 怎么做动态网站的数据库淘宝怎么设置关键词搜索
  • 怎样做网站呢手机网站制作教程
  • 做淘宝客网站再靠地推进入百度一下官网
  • 免费网络营销公司哪家好sem和seo
  • 基于dw的动物网站设计论文搜狗优化排名
  • wordpress网站加密杭州网站优化企业
  • 政府部门互联网网站建设域名注册查询网站
  • 杭州的网站建设公司哪家好公众号推广方法
  • 做饼的网站外贸如何做网站推广
  • 开通网站流程电子商务营销的概念
  • 自己做网站的成本要哪些东西推广关键词
  • 情人节网站怎么做深圳网站搜索优化
  • 做美图网站有哪些东西吗外贸推广平台哪个好