返回顶部
首页 > 资讯 > 前端开发 > html >如何使用JavaScript与Node.js打造一款聊天App
  • 847
分享到

如何使用JavaScript与Node.js打造一款聊天App

2024-04-02 19:04:59 847人浏览 薄情痞子
摘要

这篇文章将为大家详细讲解有关如何使用javascript与node.js打造一款聊天App,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。聊天是我们人与人交流

这篇文章将为大家详细讲解有关如何使用javascriptnode.js打造一款聊天App,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。

聊天是我们人与人交流最直接的方式,互联网的加入使我们交流更加便捷。我们手机上的微信、QQ是我们手机必不可少的应用软件。那么,我们是否可以做一款聊天应用呢?

之前我自己闲着没事,研究过一些技术,做了一款即时通讯应用,下面我将选取几幅具有代表性的图片供大家参考。

一、应用示图

如何使用JavaScript与Node.js打造一款聊天App

如何使用JavaScript与Node.js打造一款聊天App

如何使用JavaScript与Node.js打造一款聊天App

如何使用JavaScript与Node.js打造一款聊天App

以上是这款应用的主要页面,功能可能相对简陋点,不过基本的功能已经实现了,下面我将给出核心代码,全部源码地址在文末。

二、部分核心源码

前台主要核心逻辑:

这里我只列举了js核心代码,查看完整代码可以去文末。

function sock() {     return io.connect("Http://localhost:3003"); // http环境下 } // 心跳机制 document.addEventListener('visibilitychange', function () {     if (document.visibilityState == 'hidden') {         //记录页面隐藏时间         sock()         console.log('隐藏了')     } }) setInterval(() => {     sock() }, 10000); var Socket = sock() var re = document.querySelector("#re"); var reGISter1 = document.querySelector(".register"); var init = document.querySelector(".init"); var passr = document.querySelector("#passr"); var passl = document.querySelector("#passl"); var login1 = document.querySelector(".login"); var register_b = document.querySelector("#register_b"); var lo = document.querySelector("#lo"); var chat = document.querySelector("#chat"); var login_b = document.querySelector("#login_b"); var myMes = ""; var vf = ""; var na = ""; var p = ""; var we = ""; var div = ""; var v = ""; var q = 0; var reGCn = /[@:]/im; var pattern = /^[\u4E00-\u9FA5]{1,5}$/; // 同意 document.querySelector('.yes').onclick=function () {     document.querySelector('.dark').style.display='none' } document.querySelector('.ys').onclick = function () {     document.querySelector('.dark').style.display = 'block' } // 初始页面注册 document.querySelector("#reg").onclick = function () {     register1.style.display = "block";     init.style.display = "none";     document.querySelector(".bg").style.display = "none"; } // 初始页面登录 document.querySelector("#log").onclick = function () {     login1.style.display = "block";     init.style.display = "none";     document.querySelector(".bg").style.display = "none"; } // 登录按钮 login_b.onclick = function () {     login();  } // 注册按钮 register_b.onclick = function () {     register(); } //发送 document.getElementById("btn").onclick = function () {     send(); }; // 内容填充 document.getElementById("text").onkeyup = function () {     if (document.getElementById("text").value.length != 0) {         document.getElementById("btn").style.CSSText = "background:#98E165;color:#fff;"     } else {         document.getElementById("btn").style.cssText = "background: #DDDEE2;color:#fff"     } } document.querySelector("#text").onclick = function () {     document.querySelector('#text').scrollIntoView(false); } // 传名 var users2 = ""; socket.on('users', function (users) {     users2 = users;     //  console.log(users2); }); // 传密码 var pass2 = "" socket.on('pass', function (val) {     pass2 = val;     //  console.log(pass2) }); // 统计在线人数 var arrh = [] socket.on('dataval', function (val) {     vf = val;     console.log(vf);      for (let i = 0; i < vf.length; i++) {         // uu++         arrh.push(vf[i])         console.log(arrh)     }     var rf = [...new Set(arrh)]     console.log(rf)     rf = vf     for (let j = 0; j < rf.length; j++) {         var li = document.createElement("li");         li.classList.add("active");         li.innerText = rf[j]         console.log(rf[j])         socket.emit("time", rf[j]);         document.querySelector(".fix").appendChild(li);      } }); socket.on('join', function (val) {     document.querySelector(".fix").innerhtml = '' }) socket.on('disconnect', function (val) {     console.log('离开了')     document.querySelector(".fix").innerHTML = '' }) // 生成数组 var ar = ""; socket.on('array', function (val) {     ar = val;     // console.log(ar); }); // 封装注册 function register() {     if (re.value.length == 0) {         sweetAlert("请输入用户名!");         return false;     } else if (regCn.test(re.value)) {         sweetAlert("格式错误,不能够用和:符号取名,请重新输入!");         return false;     } else if (pattern.test(re.value)) {         sweetAlert("不能使用中文字符哦!");         return false;     } else if (!(re.value.length == 0 && regCn.test(re.value))) {         if (users2.indexOf(re.value) != -1) {             sweetAlert("已经注册啦,换一个用户名吧!");         } else {             names(re.value.trim());             pass(passr.value.trim());             sweetAlert("注册成功,您的用户名:" + re.value.trim());             document.querySelector(".swal-button").onclick = function () {                 window.location.reload();             }         }     } } //移动端使用touchend var event = navigator.userAgent.match(/(iPhone|iPod|Android|iOS)/i) ? 'touchend' : 'click';  // 选择器 var Q = function (id) {     return document.getElementById(id) }; //右 var _right = new mSlider({     dom: ".layer-right",     direction: "right" });  Q("btnRight").addEventListener(event, function (e) {     _right.open(); }) // 封装登录 function login() {     if (lo.value.length == 0) {         sweetAlert("请输入用户名!");         return false;     } else if (regCn.test(lo.value)) {         sweetAlert("格式错误,不能够用和:符号取名,请重新输入!");         return false;     } else if (pattern.test(lo.value)) {         sweetAlert("不能使用中文字符哦!");         return false;     } else if (!(lo.value.length == 0 && regCn.test(lo.value))) {         if (users2.indexOf(lo.value) != -1) {             for (var i = 0; i < users2.length; i++) {                 if (users2[i] === lo.value && pass2[i] === passl.value) {                     if (ar.indexOf(lo.value) == -1) {                         sweetAlert("恭喜您,登录成功!");                         socket.emit('setName', lo.value.trim());                         names1(lo.value.trim());                         login1.style.display = "none";                         document.querySelector(".bg").style.display = "none";                         document.querySelector(".cd span").style.display = "none";                         document.querySelector(".title img").style.display = "block";                         document.querySelector(".fix").style.display = "block";                         document.querySelector(".title").style.display = "block";                          _right.open();                         document.querySelector(".swal-button").onclick = function () {                             document.getElementById("text").focus();                             document.querySelector(".fix").addEventListener('click', function (e) {                                 if (e.target.nodeName === "LI" && e.target.innerText != document.title) {                                     _right.close();                                     document.querySelector(".chat_b").style.display = "block";                                     document.querySelector(".box").style.display = "block";                                     document.querySelector(".tit").innerText = e.target.innerText;                                     document.querySelector(".ys").style.display="none";                                     document.querySelector("#text").focus();                                     onOff = true;                                 } else {                                     sweetAlert("不能跟自己聊天哦~");                                 }                             })                         }                     } else {                         sweetAlert("不能重复登录哦!");                         return                     }                 }                 if (users2[i] === lo.value && pass2[i] != passl.value) {                     sweetAlert("密码错误!");                     return;                 }             }         } else {             sweetAlert("请先注册哦!");             login1.style.display = "none";             register1.style.display = "block";         }     } } // 传名 function names(value) {     this.name = value;     socket.emit("reg", name); }  function names1(value) {     this.name1 = value;     socket.emit("join", name1);     document.title = name1 } // 传密码 function pass(value) {     socket.emit("pass", value); } socket.on("join", function (user) {     this.na = user; }) socket.on("reg", function (user) {     this.na1 = user; }) // 私发消息 socket.on('message1', function (data) {     var p1 = document.createElement("div");     var s1 = document.createElement("p");     var s2 = document.createElement("p");     var div1 = document.createElement("div");     var em = document.createElement("em");     var ads = document.createElement("audio");     ads.src = "https://www.maomin.club/data/res.mp3";     ads.className = "ads";     s1.className = "chatlist";     s2.className = "chatlist1";     em.className = "zwasked1";     div1.className = "divbox";     s1.innerText = data.from;     s2.innerText = data.msg;     s1.appendChild(em);     p1.appendChild(s1);     p1.appendChild(s2);     chat.appendChild(ads);     ads.play();     div1.appendChild(p1);     chat.appendChild(div1);     chat.scrollTop = chat.scrollHeight; }); // 私聊发送 function send() {     if (document.getElementById("text").value != "") {         socket.emit('sayTo', {             from: lo.value,             to: document.querySelector(".tit").innerText,             msg: document.querySelector("#text").value,         })         var p1 = document.createElement("div");         var s1 = document.createElement("p");         var s2 = document.createElement("p");         var em = document.createElement("em");         var div1 = document.createElement("div");         var ads = document.createElement("audio");         p1.style.cssText = "float:right;";         s2.style.cssText = "color:#333;"         ads.src = "https://www.maomin.club/data/s.wav";         ads.className = "ads";         div1.className = "divbox";         s1.className = "chatlist";         s1.style.cssText = "color:#333 !important;float:right; !important";         s2.className = "chatlist2";         em.className = "zwasked";         s1.innerText = lo.value;         s2.innerText = document.querySelector("#text").value;         s1.appendChild(em);         p1.appendChild(s1);         p1.appendChild(s2);         chat.appendChild(ads);         ads.play();         div1.appendChild(p1);         chat.appendChild(div1);         chat.scrollTop = chat.scrollHeight;     } else {         sweetAlert('请输入内容!');     }     chat.scrollTop = chat.scrollHeight;     document.querySelector("#text").value = "";     document.querySelector("#text").focus(); }

后台主要核心逻辑:

我这里只列举了http环境的,完整代码中有https环境的。

var http=require("http"); var fs=require("fs"); var express = require('express'); var ws=require("socket.io"); var path=require("path"); var _ = require('underscore'); var usocket = []; var usocket1 = []; var pass=[]; var data=[]; var hashName = {}; var onlineCount = 0; var app = express(); // 静态文件识别 app.use(express.static(path.join(__dirname, './public'))); var server=http.createServer(function (req,res) {     var filename = req.url.split('/')[req.url.split('/').length-1];     var suffix = req.url.split('.')[req.url.split('.').length-1];     if(req.url==='/'){         res.writeHead(200, {'Content-Type': 'text/html'});         var html = fs.readFileSync("./public/index.html");         res.end(html)     }else if(suffix==='css'){         res.writeHead(200, {'Content-Type': 'text/css'});         res.end(get_file_content(path.join(__dirname, 'public', 'css', filename)));     }else if(suffix==='js') {         res.writeHead(200, {'Content-Type': 'text/javascript'});         res.end(get_file_content(path.join(__dirname, 'public', 'js', filename)));     }else if (suffix in ['gif', 'jpeg', 'jpg', 'png']) {         res.writeHead(200, {             'Content-Type': 'image/' + suffix         });         res.end(get_file_content(path.join(__dirname, 'public', 'images', filename)));     } }); function get_file_content(filepath) {     return fs.readFileSync(filepath); } // 获取在线 function broadcast() {     io.sockets.emit("dataval", hashName); } //提供私有socket function privateSocket(toId) {     return (_.findWhere(io.sockets.sockets, {         id: toId     })); } // 封装删除 function removeByValue(arr, val) {     for (var i = 0; i < arr.length; i++) {         if (arr[i] == val) {             arr.splice(i, 1);             break;         }     } } // 连接socket var io=ws(server); io.on("connection",function(socket){ // 写入成功后读取测试 fs.readFile('./user.xls', 'utf-8', function (err, data) {     if(data!=null){     var value = data.split('\n');      io.sockets.emit("users", value);       }  }); // 写入成功后读取测试 fs.readFile('./passWord.xls', 'utf-8', function (err,data) {     if(data!=null){     var pass1=data.split('\n');     io.sockets.emit("pass", pass1);     } });     broadcast(); // 生成名字 socket.on('setName', function (data) {     var name = data;     hashName[name] = socket.id;     // console.log(hashName[name]);     broadcast(); }); // 私聊发送 socket.on('sayTo', function (data) {     var toName = data.to;     var toId;     console.log(toName);     if (toId = hashName[toName]) {         privateSocket(toId).emit('message1', data);     } }); // 离开 socket.on('disconnect', function (name) {          name=this.i2;          io.emit("disconnect", name);          removeByValue(data, name);          io.sockets.emit("dataval", data);     }) // 在线 socket.on('time', function (val) {         // console.log(val);    }) // 注册 socket.on("reg", function (name) {           usocket[name] = socket;           this.i1=name;           io.emit("reg", name);           var myname =this.i1+"\n";           fs.writeFile('./user.xls', myname, {               'flag': 'a'           }, function (err) {               if (err) {                   throw err;               }               // 写入成功后读取测试               fs.readFile('./user.xls', 'utf-8', function (err,data) {                   if (err) {                       throw err;                   }               });           });     }) // 加入 io.emit('connected', ++onlineCount);     // console.log(data);     io.sockets.emit("array", data);     socket.on("join", function (name) {         usocket1[name] = socket;         this.i2 = name;         io.emit("join", name);         data.push(name);         io.sockets.emit("dataval", data);     }) // 密码 socket.on("pass",function(val){       pass[val]=socket;       this.i2=val;       io.emit("pass", val);       var password=this.i2+"\n";        fs.writeFile('./password.xls', password, {               'flag': 'a'           }, function (err) {               if (err) {                   throw err;               }           });     }) }); server.listen(3003); console.log("服务器运行中");

三、源码地址

这个项目是之前写的,欢迎大家进行指正。大家可以复制下面的源码地址,拉取下来就可以在本地实现一个聊天服务。如果你有服务器可以把它部署在服务器上,这样你就可以有一个属于自己的聊天App了。大家可以根据源码进行学习,有不明白的可以随时问我。

https://GitHub.com/maomincoding/chat3

关于如何使用JavaScript与Node.js打造一款聊天App就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。

--结束END--

本文标题: 如何使用JavaScript与Node.js打造一款聊天App

本文链接: https://lsjlt.com/news/82316.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • 如何使用JavaScript与Node.js打造一款聊天App
    这篇文章将为大家详细讲解有关如何使用JavaScript与Node.js打造一款聊天App,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。聊天是我们人与人交流...
    99+
    2024-04-02
  • 如何用webSocket与Swoole打造一个小型聊天室
    这篇文章主要介绍了如何用webSocket与Swoole打造一个小型聊天室的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇如何用webSocket与Swoole打造一个小型聊天室文章都会有所收获,下面我们一起来看...
    99+
    2023-06-29
  • 如何用JavaEE7、Websockets和GlassFish4打造聊天室(一)
    今天就跟大家聊聊有关如何用JavaEE7、Websockets和GlassFish4打造聊天室(一),可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。Java EE 7已经在今年正式发布...
    99+
    2023-06-17
  • 如何利用Python打造一个多人聊天室
    这篇文章主要介绍如何利用Python打造一个多人聊天室,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!一、实验名称建立聊天工具二、实验目的掌握Socket编程中流套接字的技术,实现多台电脑之间的聊天。三、实验内容和要求...
    99+
    2023-06-22
  • 如何使用JavaScript+Node.js写一款markdown解析器
    这篇文章主要介绍了如何使用JavaScript+Node.js写一款markdown解析器,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。1. 准备工作首先编写getHtml函...
    99+
    2023-06-29
  • 如何用Node.JS打造一个恶劣天气实时预警系统
    这篇文章主要讲解了“如何用Node.JS打造一个恶劣天气实时预警系统”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“如何用Node.JS打造一个恶劣天气实时预警系统”吧!序言:这几日,无论是打...
    99+
    2023-06-25
  • Android开发如何使用WebView打造web app
    这篇文章主要为大家展示了“Android开发如何使用WebView打造web app”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“Android开发如何使用WebView打造web&n...
    99+
    2023-06-29
  • Node.js websocket如何使用socket.io库实现实时聊天室
    这篇文章主要介绍Node.js websocket如何使用socket.io库实现实时聊天室,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!认识websocketWebSocket p...
    99+
    2024-04-02
  • 如何使用Redis和Node.js开发实时聊天功能
    如何使用Redis和Node.js开发实时聊天功能随着互联网的发展,实时通信已成为许多网站和应用程序必不可少的功能之一。在众多实时通信的技术中,Redis和Node.js的结合是一种非常强大和流行的选择。Redis是一种高性能的键值存储数据...
    99+
    2023-10-22
    redis nodejs 实时聊天
  • 如何使用Java带你打造一款简单的外卖系统
    本篇内容介绍了“如何使用Java带你打造一款简单的外卖系统”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成! 【一、项目背景】随着互联...
    99+
    2023-06-15
  • 如何从零打造一款轻量且天然支持SSR的CMS系统-SimpleCMS
    这篇文章主要讲解了“如何从零打造一款轻量且天然支持SSR的CMS系统-SimpleCMS”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“如何从零打造一款轻量且...
    99+
    2024-04-02
  • 如何利用html5和css3打造一款创意404页面
    这篇文章主要讲解了“如何利用html5和css3打造一款创意404页面”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“如何利用html5和css3打造一款创意...
    99+
    2024-04-02
  • 聊天素材支持小程序打开如何使用
    本篇内容介绍了“聊天素材支持小程序打开如何使用”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!  功能介绍  微信聊天内素材(图片、视频和we...
    99+
    2023-06-26
  • 如何使用MySQL和JavaScript实现一个简单的即时聊天功能
    如何使用MySQL和JavaScript实现一个简单的即时聊天功能随着社交媒体的普及,即时聊天已经成为了人们日常生活中必不可少的一部分。在这篇文章中,我们将介绍如何使用MySQL和JavaScript来实现一个简单的即时聊天功能。首先,我们...
    99+
    2023-10-22
    MySQL JavaScript 即时聊天
  • 如何使用vue3打造一个物料库
    目录为什么要做物料库?物料是什么?物料的类别fuep,基于vue3的物料库为什么要做物料库? 我们写过很多登录页面。而每个登录页面除了一些背景图和颜色外,主体布局几乎是一致的,就那...
    99+
    2024-04-02
  • 如何使用JS将聊天记录聚合在一起
    这篇文章主要介绍了如何使用JS将聊天记录聚合在一起,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。实现思路先跟大家看下我的数据,如下所示:[{...
    99+
    2024-04-02
  • 如何使用MongoDB开发一个在线聊天系统
    如何使用MongoDB开发一个在线聊天系统引言:在这个信息化的时代,人们需要更加高效和便捷的沟通方式。在线聊天系统已经成为了许多人日常生活中必不可少的一部分。本文将介绍如何使用MongoDB数据库开发一个简单而实用的在线聊天系统,并提供具体...
    99+
    2023-10-22
    开发 MongoDB 在线聊天系统
  • 如何使用node开发一款图集打包工具
    这篇文章主要为大家展示了“如何使用node开发一款图集打包工具”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“如何使用node开发一款图集打包工具”这篇文章吧。比...
    99+
    2024-04-02
  • 如何使用MySQL和Java实现一个简单的聊天室功能
    要使用MySQL和Java实现一个简单的聊天室功能,你需要进行以下步骤:1. 创建数据库和表:使用MySQL创建一个数据库,并在该数...
    99+
    2023-10-10
    MySQL
  • 从 Python 开发技术到 shell 和 laravel:如何打造一款完美的应用程序?
    从 Python 开发技术到 shell 和 Laravel:如何打造一款完美的应用程序? 现如今,我们离不开各种各样的应用程序。无论是移动应用,还是网页应用,它们都是依靠程序员的努力打造而成。打造一款完美的应用程序需要不断地学习和尝试,使...
    99+
    2023-08-17
    开发技术 shell laravel
软考高级职称资格查询
推荐阅读
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作