vscode如何使用ajax,Ajax 的初步实现(使用vscode+node.js+express框架)

需求: 点击按钮 向服务端发送一个请求 然后将服务端返回的响应体结果在一个div中呈现出来 同时页面不刷新

一、 服务端的前期准备

检验是否安装成功 : 在命令行输入 node -v 按下enter 键之后出现 版本号就表明安装成功 (图如下)

ba5a0de02015da55c245d588cd7aeef6.png

使用 vscode安装express (前提是你已经成功安装了node.js)

在 vscode 里面新建一个文件夹 文件下面包含俩个文件 一个是你的前端页面代码:.html另一个是准备的服务端代码 这里暂且为 server.js在目录文件最外层 点击在集成终端中打开

017de3c59c20507f892206c82a500a40.png

输入 npm init 进行初始化 输入包名后一直按 Enter 就行

ea6b399c0e7c0e38b0dac8e272716809.png

5. 继续输入 npm i express 安装express 框架

15383db9053a7f712cf2238b6909486b.png

6.文件目录下你会看到生成了 package-lock.json 文件 以及 node_modules 文件 此时说明你的框架安装好了

express的基本使用 (该js文件名为 express基本使用.js):

1 .

//1. 引入express

const express = require('express');

//2. 创建应用对象

const app = express();

//3. 创建路由规则

// request 是对请求报文的封装

// response 是对响应报文的封装

app.get('/', (request, response) => {

//设置响应

response.send('HELLO EXPRESS 1');

});

app.post('/', (request, response) => {

//设置响应

response.send('HELLO EXPRESS 2');

});

app.all('/', (request, response) => {

//设置响应

response.send('HELLO EXPRESS 3');

});

//4. 监听端口启动服务

app.listen(8000, () => {

console.log("服务已经启动, 8000 端口监听中....");

});

在集成终端中输入 node -express基本使用.js

28170dc94071cd772b69971d162cad73.png

3. 在浏览器中地址栏输入: http://127.0.0.1:8000/ 看到如下图 即服务端配置完成

5b3344f165357cff7993dd7d9ccb08d1.png

二、 客户端的准备(前端代码 都引用了jquery来获取Dom元素)

点击按钮 向服务端发送一个请求 然后将服务端返回的响应体结果在一个div中呈现出来 同时页面不刷新

使用原生的 ajax :

AJAX GET 请求

#result {

width: 200px;

height: 100px;

border: solid 1px red;

}

发送请求

// 1.获取元素 给按钮添点击事件

$('button').on('click', function () {

// alert(1);

// 2.创建对象

const xhr = new XMLHttpRequest();

// 3.初始化 设置请求方式 和url

xhr.open('GET', 'http://127.0.0.1:8000/server');

// 4.发送

xhr.send();

// 5.事件绑定 处理服务器返回的结果

xhr.onreadystatechange = function () {

// readystate 是 xhr 对象中的属性 有 0 1 2 3 4

// 判断(4 表示服务端返回了所有的结果)

if (xhr.readyState == 4) {

if (xhr.status >= 200 && xhr.status < 300) {

// 处理结果有: 行 头 空行 体

// 1.响应行

// 2.将响应体 返回到客户端页面中

$('div').html(xhr.response);

}

}

else {

}

}

})

必须注意

93726a9ed7489f89e0bc6b5f07e03dcf.png

三、 运行程序

在目录文件夹右键在集成终端中打开 输入: node server.js

9b0af531a8dde79f7027d5eaac03bae1.png

331e8597e095c7a3790e42da62d53780.png

运行 html 代码

b575b00e8f70899046a30e2a94db5ab0.png

点击发送请求

a4a147908dc23696b3a267bbd8cda42e.png

注: 至此 Ajax 已基本实现 !!

为了方便执行js脚本代码 避免老是重复开启窗口 我们这里 还需安装 nodemon 安装方式与express 一样 在终端输入:npm install -g nodemon

bf7fb10b76b7bd478eaa38cbee4f18d9.png

如果你不想下载jquery引入 你可以在网页上输入 bootcdn https://www.bootcdn.cn/

e873dbbeba21ed240407d48504cfcefe.png

8cb92bd54da0da57d229125bffc76ab9.png

a913b5a14c3e30788d330bcfa5feeb20.png

注:为了防止报错前面添加 crossorign="anonymous"

以上就是Ajax 的初步实现(使用vscode+node.js+express框架)的详细内容,更多关于Ajax初步实现的资料请关注脚本之家其它相关文章!

  • 4
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
首先,要使用Node.js和Socket.io搭建一个基本的聊天室,可以参考以下步骤: 1. 安装Node.js和npm 2. 创建一个新的Node.js项目并在项目文件夹里打开命令行 3. 在命令行输入以下命令来安装Socket.io: ``` npm install socket.io ``` 4. 创建一个新的文件夹用于存放服务器端代码,我们称之为“server” 5. 在“server”文件夹创建一个新的JavaScript文件,例如“server.js” 6. 在“server.js”添加以下代码: ``` const io = require('socket.io')(); io.on('connection', (socket) => { console.log('a user connected'); socket.on('disconnect', () => { console.log('user disconnected'); }); }); io.listen(3000); ``` 7. 在命令行进入“server”文件夹并运行“server.js”文件: ``` node server.js ``` 8. 创建一个新的文件夹用于存放客户端代码,我们称之为“client” 9. 在“client”文件夹创建一个新的HTML文件,例如“index.html” 10. 在“index.html”添加以下代码: ``` <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title>Socket.io Chat Room</title> </head> <body> <h1>Socket.io Chat Room</h1> <div id="messages"></div> <form id="message-form"> <input type="text" id="input-message" placeholder="Type your message here..."> <button type="submit">Send</button> </form> <script src="https://cdn.socket.io/socket.io-3.0.1.min.js"></script> <script src="client.js"></script> </body> </html> ``` 11. 在“client”文件夹创建一个新的JavaScript文件,例如“client.js” 12. 在“client.js”添加以下代码: ``` const socket = io('http://localhost:3000'); const messageForm = document.getElementById('message-form'); const inputMessage = document.getElementById('input-message'); const messages = document.getElementById('messages'); messageForm.addEventListener('submit', (event) => { event.preventDefault(); const message = inputMessage.value; if (message) { socket.emit('chat message', message); inputMessage.value = ''; } }); socket.on('chat message', (message) => { const li = document.createElement('li'); li.textContent = message; messages.appendChild(li); }); ``` 13. 在命令行进入“client”文件夹并运行以下命令: ``` npm install express ``` 14. 在“client”文件夹创建一个新的JavaScript文件,例如“server.js” 15. 在“server.js”添加以下代码: ``` const express = require('express'); const app = express(); app.use(express.static('public')); app.listen(8080, () => { console.log('Server running on http://localhost:8080'); }); ``` 16. 在命令行进入“client”文件夹并运行以下命令: ``` node server.js ``` 现在你就可以在浏览器打开“http://localhost:8080”并开始聊天了。 要实现私聊和创建群聊的功能,你需要在服务器端和客户端添加一些额外的代码。 对于私聊功能,你可以创建一个“私聊房间”,只有被邀请的用户才能加入该房间,并在该房间进行私人对话。以下是一些可能有用的代码: 1. 服务器端: ``` const users = {}; io.on('connection', (socket) => { console.log('a user connected'); socket.on('login', (username) => { users[username] = socket.id; console.log(`${username} logged in`); }); socket.on('invite', (username) => { const roomId = `${socket.id}:${users[username]}`; socket.join(roomId); io.to(users[username]).emit('invited', roomId); }); socket.on('chat message', (data) => { const { message, roomId } = data; io.to(roomId).emit('chat message', message); }); socket.on('disconnect', () => { console.log('user disconnected'); }); }); ``` 2. 客户端: ``` const socket = io('http://localhost:3000'); const username = prompt('What is your name?'); socket.emit('login', username); let roomId = null; const inviteForm = document.getElementById('invite-form'); const inviteInput = document.getElementById('invite-input'); inviteForm.addEventListener('submit', (event) => { event.preventDefault(); const username = inviteInput.value; if (username) { socket.emit('invite', username); inviteInput.value = ''; } }); socket.on('invited', (id) => { roomId = id; messages.innerHTML = ''; messageForm.style.display = 'block'; }); messageForm.addEventListener('submit', (event) => { event.preventDefault(); const message = inputMessage.value; if (message) { socket.emit('chat message', { message, roomId }); inputMessage.value = ''; } }); socket.on('chat message', (message) => { const li = document.createElement('li'); li.textContent = message; messages.appendChild(li); }); ``` 对于创建群聊功能,你可以创建一个“群聊房间”,所有用户都可以加入该房间,并在该房间进行群聊。以下是一些可能有用的代码: 1. 服务器端: ``` const rooms = {}; io.on('connection', (socket) => { console.log('a user connected'); socket.on('create room', () => { const roomId = socket.id; socket.join(roomId); rooms[roomId] = { name: `Room ${Object.keys(rooms).length + 1}` }; io.to(roomId).emit('room created', roomId); console.log(`Room ${roomId} created`); }); socket.on('join room', (roomId) => { socket.join(roomId); io.to(roomId).emit('user joined', { username: 'anonymous', message: 'joined the chat' }); console.log(`User ${socket.id} joined room ${roomId}`); }); socket.on('chat message', (data) => { const { message, roomId } = data; io.to(roomId).emit('chat message', message); }); socket.on('disconnect', () => { console.log('user disconnected'); }); }); ``` 2. 客户端: ``` const socket = io('http://localhost:3000'); const createRoomButton = document.getElementById('create-room-button'); const joinRoomForm = document.getElementById('join-room-form'); const joinRoomInput = document.getElementById('join-room-input'); createRoomButton.addEventListener('click', () => { socket.emit('create room'); }); joinRoomForm.addEventListener('submit', (event) => { event.preventDefault(); const roomId = joinRoomInput.value; if (roomId) { socket.emit('join room', roomId); joinRoomInput.value = ''; messages.innerHTML = ''; messageForm.style.display = 'block'; } }); socket.on('room created', (roomId) => { const option = document.createElement('option'); option.value = roomId; option.textContent = `Room ${Object.keys(rooms).length}`; selectRoom.appendChild(option); }); socket.on('user joined', (data) => { const { username, message } = data; const li = document.createElement('li'); li.textContent = `${username} ${message}`; messages.appendChild(li); }); socket.on('chat message', (message) => { const li = document.createElement('li'); li.textContent = message; messages.appendChild(li); }); ``` 以上代码只是一个简单的示例,你可以根据自己的需求进行更改和扩展。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值