简言 (YouChat)
基于webSocket的web通信应用(兼容移动端),后台使用node+express搭建基础http服务,使用socket.io搭建通讯层的ws服务。实现了全部成员的群聊、针对某一成员的私聊以及新消息提示等一些常用功能。前端用原生js编写实现了发送表情以及发送本地图片功能,还用到了 manifest 相关的一些概念,可以通过桌面直接进入。
Git仓库
https://github.com/cp0725/YouChat
启动流程
cd/YouChat
npm install
node server.js
本地访问地址 http://127.0.0.1:8686/YouChat
(没顾上做动态编译 webpack
是构建命令每次修改代码都要运行一次)
登录页
data:image/s3,"s3://crabby-images/ef9a5/ef9a541cae7114d6543106ccb4bd71ca117e524f" alt=""
群聊以及私聊功能
data:image/s3,"s3://crabby-images/aa0f4/aa0f4fbe09dcc85821edb92461ebc9eb4627728a" alt=""
data:image/s3,"s3://crabby-images/2257c/2257c244b4cbd6949c76e59eb9603a222f39aade" alt=""
发送表情包发送本地图片
data:image/s3,"s3://crabby-images/7cc19/7cc196bd36e73f044188da19d5caa0c0869cb1ae" alt=""
移动端UI展现
data:image/s3,"s3://crabby-images/2ef81/2ef81c9df5293721b7631167baf4627f7608704e" alt=""
data:image/s3,"s3://crabby-images/e89f1/e89f143cea168b46b25591770ae6be4c7b7ceab1" alt=""
data:image/s3,"s3://crabby-images/9e54b/9e54be8c2e5da30c2380ee4895ed8e611c3da36e" alt=""
h5 Notification 的表现效果
data:image/s3,"s3://crabby-images/d7c13/d7c13faffbd6e10d8bc3b97394099ea0cc6294aa" alt=""
data:image/s3,"s3://crabby-images/40cc1/40cc19dfd0a1dfc72d8b66341c29a32f8ef32e6c" alt=""
另外要说两个知识点是 manifest 和 Notification
manifest
manifest是PWA用到的一个技术点,关于PWA早就想学习一下了,直到最近才看了官方的文档,我们用link标签在页面头部引入一个manifest配置文件,在manifest配置文件里可以配置页面图标、启动动画、应用名称等一些属性,然后通过浏览器把应用发送到桌面下次就可以直接从桌面进入,表现的效果接近原生的app,因为隐藏了浏览器的一些工具栏等操作区。交互性能上也要好很多,下面是相关的表现UI。
桌面图标
data:image/s3,"s3://crabby-images/72384/723848f5246e127745e0ce700ae590f613652dc1" alt=""
启动动画
data:image/s3,"s3://crabby-images/0ba43/0ba437625a86d9159244bf3806a90c0d9ca0e33b" alt=""
主要功能
data:image/s3,"s3://crabby-images/45caa/45caad7bd28b3cba926a41541ad94635fe435a32" alt=""
data:image/s3,"s3://crabby-images/2099a/2099afbca6acfb1c6dd3f659eaf4e71f1fa4074e" alt=""
manifest只是PWA相关技术栈的一个技术点,PWA还涉及到离线加载等很多的东西,本应用就只是用manifest配置了一下展现UI。
Notification
Notification是H5的api作用是基于浏览器来触发消息通知而不是页面,也就是说把页面最小化或者切换到别的tab页,Notification的通知消息还是可以正常触发。但是有一个限制在Chrome里必须是https协议,而safari则不对协议做限制,UI表现在上面已经给出来了。
网友评论