首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往
您找到你想要的搜索结果了吗?
是的
没有找到

Node.js - 200 多行代码实现 Websocket 协议

到网上搜罗了一番资料后用 Node.js 实现该协议,倒也没有想象中那么复杂,除去注释语句和 console 语句后,大约 200 行代码左右。本文记录了实现过程中的经验和总结。...2、知识储备 如果要自己写一个 Websocket 服务,主要有两个难点: 熟练掌握 Websocket 的协议,这个需要多读现有的解读类文章;(下面会给出参考文章) 操作二进制数据流,在 Node.js...Bit),不太清楚的,可以参考 LSB最低有效位和MSB最高有效位 具体的做法如下,推荐先阅读以下几篇参考文章: 学习WebSocket协议—从顶层到底层的实现原理(修订版):作者本身自己就用 Node.js...B、 实战 实现代码放在自己的 demos 仓库的 micro-ws 的目录 了,git clone 后本地运行,执行 node index.js 将会在 http://127.0.0.1:3000...5、总结 从刚开始决定阅读 Websocket 协议,到自己使用 Node.js 实现一套简单的 Websocket 协议,到这篇文章的产出,前后耗费大约 1 个月时间(拖延症。。。)。

2.5K31

JS】547- 200JS代码,带你实现代码编译器(人人都能学会)

其实我们也经常接触到编译器的使用场景: React 中 JSX 转换成 JS 代码; 通过 Babel 将 ES6 及以上规范的代码转换成 ES5 代码; 通过各种 Loader 将 Less / Scss...接下来进入本文主题:「200JS代码,带你实现代码编译器」。 二、编译器介绍 2.1 程序运行方式 现代程序主要有两种编译模式:静态编译和动态解释。...Runtime (运行时) 包大小 较小 较大 执行性能 更好 - 启动时间 更短 - 除此之外 AOT 还有以下优点: 在客户端我们不需要导入体积庞大的 angular 编译器,这样可以减少我们 JS...最后,文中介绍到的代码,我存放在 Github 上: [learning]the-super-tiny-compiler.js[4] [writing]webpack-compiler.js[5] 六、...Super Tiny Compiler: https://the-super-tiny-compiler.glitch.me/ [4] [learning]the-super-tiny-compiler.js

2.6K40

200行Html5+CSS3+JS代码实现动态圣诞树

一、前言 最近CSDN的热榜出现了很多用Python、C/C++等编程语言实现的圣诞树,发现很少用前端的,这篇文章用前端三大杀手Html5、CSS、Js来实现动态圣诞树。...效果展示: 备注: 整体圣诞树分为3个部分,书的主干、粒子特效、树上的卡片 树上的卡片(重点):每一张卡片上都有一个名字,代表圣诞树的叶子,后面可以根据自己需求更改,比如全部改成喜欢人的名字,在JS...代码的第五行内更改内容 树的动态旋转通过js实现、主干是html5、样式CSS 三、步骤 1.下载VSCode 下载链接:VSCode 在Hbuilder、idea运行也是可以的,这里推荐使用VSCode...让代码在网页中打开,默认键Alt+B 3.构建三个文件 在桌面新建一个空的文件夹,用VSCode打开 在VSCode新建三个文件 index .html domtree.css domtree.js...(${ry}deg) rotateZ(${rz}deg)`; tree.appendChild( element ); } // Let it snow for( var i = 0; i < 200

4K20

前端-微信小程序之圆形进度条

1.先绘制背景 (1)在js中封装一个画圆环的函数drawProgressbg,canvas 画圆 (2)在onReady中执行这个函数; 小程序canvas组件与H5的canvas有点差别,请查看文档...2.绘制彩色圆环 (1)在js中封装一个画圆环的函数drawCircle, (3)在onReady中执行这个函数; 代码如下: drawCircle: function (step){      var...wx.createCanvasContext('canvasProgress');      // 设置渐变      var gradient = context.createLinearGradient(200..., 100, 100, 200);      gradient.addColorStop("0", "#2661DD");      gradient.addColorStop("0.5", "#40ED94...3.设置一个定时器 (1)在js中的data设置一个计数器 count,一个步骤step,一个定时器 (2)在js中封装一个定时器的函数countInterval, (3)在onReady中执行这个函数

1.2K40
领券