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

服装公司网站规划建设阿里云网站建设教程视频

服装公司网站规划建设,阿里云网站建设教程视频,湖北建设厅官方网站,广州专业的网站制作实现思路和vue中是一样的。如果想看思路可以看这篇文章:websocket 直接上可以运行的代码: 一、后端nodeJS代码: 1、新建项目文件夹 2、初始化项目: npm init -y 3、项目里安装ws npm i ws --save 4、nodeJS代码&#xff1…

实现思路和vue中是一样的。如果想看思路可以看这篇文章:websocket

直接上可以运行的代码:

一、后端nodeJS代码:

1、新建项目文件夹

2、初始化项目:

npm init -y

3、项目里安装ws

npm i ws --save

4、nodeJS代码:

chat.js

const WsServer = require("ws").Server;// 创建webscoket的服务器对象
const server = new WsServer({ port: 9000 });// 绑定connection事件(当有浏览器端连接时,会触发)let allClient = []; //保存着所有的客户端server.on("connection", (client) => {console.log("有人连接了");// 保存连接的客户端allClient.push(client);console.log("allClient.length", allClient.length);// 给所有客户端发送人数:sendCount();// 给当前客户端对象绑定message事件(当前该客户端给服务器发送消息时,触发client.on("message", (str) => {console.log("有人发了消息",str);// 把收到的消息转发给其它客户端sendMsg(client,str);});client.on("close", () => {sendMsg(client,"有人退出了");allClient = allClient.filter((item) => item != client);sendCount();});
});
// 发送消息
function sendMsg(client,content) {allClient.forEach((item) => {if (item != client) {item.send(JSON.stringify({status: "msg",content,}));}});
}// 发送人数
function sendCount() {allClient.forEach((item) => {item.send(JSON.stringify({status: "count",count: allClient.length,}));});
}

5、运行后端项目:

nodemon chat

二、前端uni-app代码

1、uni-app代码

<template><view><view>聊天:在线人数:{{count}}</view><view class="chat-box" v-html="allmsg"></view><input v-model="msg" /><button @click="sendMsg">发送</button><button @click="exitChat">退出聊天</button></view>
</template><script>export default {data() {return {allmsg: "",msg: "",count: 0}},onLoad() {const socketTask = uni.connectSocket({url: "ws://127.0.0.1:9000/",success() {}});console.log("socketTask", socketTask);uni.onSocketOpen(() => {console.log("服务器已经打开链接");// ws.send("大家好,我是新来的");uni.sendSocketMessage({data: "大家好,我是通过uni来的"})})uni.onSocketMessage((res) => {console.log('收到服务器内容:' + res.data);// this.allmsg += `<view>${res.data}</view>`;const obj = JSON.parse(res.data);if (obj.status == "msg") {console.log("typeof obj.content", typeof obj.content);console.log("obj.content", obj.content);this.allmsg += `<view>${this.blobToStr(obj.content.data)}</view>`;} else if (obj.status === "count") {console.log("obj.count", obj.count);this.count = obj.count;}})},methods: {exitChat(){uni.closeSocket();},blobToStr(data) {var enc = new TextDecoder("utf-8");var arr = new Uint8Array(data);return enc.decode(arr)},sendMsg() {uni.sendSocketMessage({data: this.msg})}}}
</script><style scoped>.chat-box {width: 100%;height: 800rpx;border: 1px solid red;}
</style>

2、运行项目,界面如下:

解释:当打开前端页面时,后端的socket会自动连接上

 

 

http://www.yayakq.cn/news/365361/

相关文章:

  • 通过wordpress小程序发布文章北京网站优化怎么样
  • 沧州做企业网站Wordpress对接阿里云OSS
  • 上海教育网站前置审批网站运营介绍
  • 冠县网站建设wordpress百度搜索
  • 网站 前台后台有没有不花钱建设网站的方法
  • 免费推广网站58网上找装修设计
  • 博客做网站网站建设与管理资料下载
  • 直接IP做访问我服务器的网站网页设计模板html代码 div
  • 做网站维护上海专业的网站建设公司
  • 建立网站的申请邢台网页美工
  • 闲置tp路由自己做网站我的世界做外国壁纸网站
  • 广州市住房和城乡建设局官方网站海南省住房城乡建设厅网站首页
  • 怎样查询网站空间慈溪市建设厅网站
  • 广州网站设计教程推广引流方法有哪些?
  • 阅读分享网站模板找百度做的网站可以过户
  • 网站免费建站系统 六浏览器打不开网页是什么原因
  • 网站推广有必要吗网络广告的形式
  • 做网站要钱嘛建设部执业注册中心网站
  • 做网站技术系统开发过程中设计代码的原则为
  • 佛山网站建设费用商务网站建设营销
  • 网站建设好学吗wordpress优秀案例
  • 医院网站cms网页与网站设计实验总结
  • 自建站怎么做30个无加盟费的项目
  • 如何做地方网站WordPress文件归档
  • 用ip做网站网络推广营销策划方案
  • 彩票网站开发是否可以游戏开科技怎么开
  • 巩义网络建设网站wordpress建站wifi
  • 外链数是网站反向链接码wordpress评论 边栏
  • 做网站时需要FTP工具吗茂名百度搜索网站排名
  • 网站建设任职要求赣州网上银行登录