您的位置:首页 > 游戏 > 手游 > b站推广网站2024已更新_东莞专业网_猪肉价格最新消息_网络推广有哪些常见的推广方法

b站推广网站2024已更新_东莞专业网_猪肉价格最新消息_网络推广有哪些常见的推广方法

2024/12/22 23:42:15 来源:https://blog.csdn.net/2401_87333857/article/details/144012812  浏览:    关键词:b站推广网站2024已更新_东莞专业网_猪肉价格最新消息_网络推广有哪些常见的推广方法
b站推广网站2024已更新_东莞专业网_猪肉价格最新消息_网络推广有哪些常见的推广方法

一:express框架

在终端输入node+js文件名

// 引入express
const express = require('express');
//创建应用对象
const app = express();
//创建路由规则
app.get('/',(request,response) => {//设置响应response.send('Hello Express');
});    // 监听3000端口
app.listen(8000,()=>{console.log("服务器已经启动");  // 启动成功后,在命令行中看到此消息
});

Ctrl+c结束服务器

二:ajax入门:

// 引入express
const express = require('express');
//创建应用对象
const app = express();
//创建路由规则
app.get('/server',(request,response) => {//设置响应头,设置允许跨域response.setHeader('Access-Control-Allow-Origin','*');//设置响应response.send('Hello ajax');
});    app.POST('/server',(request,response) => {//设置响应头,设置允许跨域response.setHeader('Access-Control-Allow-Origin','*');//设置响应response.send('Hello ajax post');
});  // 监听8000端口
app.listen(8000,()=>{console.log("服务器已经启动");  // 启动成功后,在命令行中看到此消息
});

 get请求

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>Document</title><style>#result{width: 200px;height: 100px;border: 1px solid black;}</style>
</head>
<body><button>点击发送请求</button><div id="result"></div><script>//获取按钮元素const btn =document.getElementsByTagName('button')[0];const result = document.getElementById('result');//添加点击事件btn.onclick = function(){//1.创建对象const xhr = new XMLHttpRequest();//2.初始化xhr.open('GET','http://127.0.0.1:8000/server?a=100&b=200');//3. 发送请求xhr.send();//4.时间绑定//on when 当...时候//readystate 是xhr的一个属性,值有0-4,//分别代表请求未发送,请求发送中,请求发送完成,响应头部接收完成,响应数据接收完成//改变状态函数xhr.onreadystatechange = function(){//判断(服务端返回了所有的结果)if(xhr.readyState===4){//判断(状态码是否为200,即服务器返回了正确的数据)//响应状态码分别有200 404 500等if(xhr.status>=200&&xhr.status<300){//处理结果//获取状态码console.log(xhr.status);//状态状态字符串console.log(xhr.statusText);//返回所有响应头console.log(xhr.getAllResponseHeaders);//响应体console.log(xhr.response);}else{console.log('请求出错');}result.innerHTML=xhr.response;}}}</script>
</body>
</html>

post请求

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>POST请求</title><style>#result{width: 200px;height: 100px;border: 1px solid black;}</style>
</head>
<body><div id="result"></div><script>const result = document.getElementById("result");result.addEventListener("mouseover",function(){// console.log("mouseover");const xhr = new XMLHttpRequest();xhr.open("POST","http://127.0.0.1:8000/server");xhr.send();xhr.onreadystatechange=function(){if(xhr.readyState===4 && xhr.status===200){if(xhr.status>=200&&xhr.status<300){result.innerHTML=xhr.response;}}}})</script>
</body>
</html>

 设置请求头信息:

 服务器需要设置响应头,all可以接受任何的请求

response.setHeader('Access-Control-Allow-Headers','*');

设置允许跨域(自己命名的请求头信息)

app.all('/server',(request,response) => {//设置响应头,设置允许跨域response.setHeader('Access-Control-Allow-Origin','*');//设置响应头, 设置允许跨域的头部response.setHeader('Access-Control-Allow-Headers','*');//设置响应response.send('Hello ajax post');
});  

服务器端响应json数据

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>json</title><style>#result{width: 200px;height: 100px;border: 1px solid black;}</style>
</head>
<body><div id="result"></div><script>const result=document.getElementById('result');//绑定键盘按下事件window.onkeydown = function(){// console.log('test');//发送请求const xhr = new XMLHttpRequest();//设置响应体数据类型xhr.responseType='json';xhr.open('GET', 'http://127.0.0.1:8000/json-server');xhr.send();xhr.onreadystatechange = function(){if(xhr.readyState===4)if(xhr.status>=200 && xhr.status<300){// console.log(xhr.response);// result.innerHTML=xhr.response;//手动对数据转化// let data = JSON.parse(xhr.response);// console.log(data);// result.innerHTML=data.name;//自动转化console.log(xhr.response);result.innerHTML=xhr.response.name;}}}</script>
</body>
</html>

nodemon自动重启工具

 在终端中输入 npm install -g nodemon指令

安装完成之后只需要打node+tab就可以

ajaxIE的缓存问题

只需要加一个时间戳就可以

延迟请求

超过两秒请求取消

让网络离线,报异常

ajax手动取消

注意这里使用的是let xhr =null

重复请求问题

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com