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

有没有做黑市网站昆明参差网站

有没有做黑市网站,昆明参差网站,网络培训合同履行地如何确定,深圳市网络营销推广品牌Ajax(Asynchronous JavaScript And XML)即异步 JavaScript 和 XML,是一组用于在网页上进行异步数据交换的 Web 开发技术,可以在不刷新整个页面的情况下向服务器发起请求并获取数据,然后将数据插入到网页中的某个位置。…

Ajax(Asynchronous JavaScript And XML)即异步 JavaScript 和 XML,是一组用于在网页上进行异步数据交换的 Web 开发技术,可以在不刷新整个页面的情况下向服务器发起请求并获取数据,然后将数据插入到网页中的某个位置。这种技术能够实现增量式更新页面,提高用户交互体验,减少响应时间和带宽的消耗。

1. Ajax 介绍

使用 Ajax 技术,可以通过 JavaScript 和 XMLHttpRequest 对象来向服务器获取数据。在 Ajax 请求的过程中,可以通过定义回调函数来对请求的结果进行处理,回调函数会在请求完成后执行,通过这种方式可以更新页面内容或者响应用户操作。

1.1 Ajax 可以用来实现以下功能

  1. 异步更新页面内容(如搜索建议、聊天框等)
  2. 在页面中特定区域显示动态数据
  3. 提交表单数据而无需刷新整个页面
  4. 与服务器进行交互,不会导致页面跳转或刷新

1.2 Ajax 的主要优点包括

  1. 提高用户体验:通过减少页面的重载和刷新,使得网站变得更加灵活和动态。
  2. 减轻服务器负载:通过使用 Ajax,可以有效减少服务器接收到的请求次数和需要响应的数据量,从而减轻服务器的负担。
  3. 提高响应速度:使用 Ajax 可以异步获取数据并更新页面,从而提高响应速度。
  4. 增加交互性:通过使用 Ajax,可以使得页面变得更加动态和交互性。

1.3 Ajax 的不足

  1. Ajax 对搜索引擎优化(Seo)劣势较大,对于需要 SEO 的项目需要谨慎选择使用 Ajax 技术。
  2. 在使用 Ajax 时,需要考虑数据安全性和网络安全性问题,并采取相应的措施加以防范。
  3. 不合适的使用 Ajax,可能会造成降低网站质量和效率的问题,所以需要根据实际需求来决定是否采用该技术。

2. 核心 API

  1. 使用 Ajax 技术,可以通过 JavaScript 和 XMLHttpRequest 对象来向服务器获取数据。在 Ajax 请求的过程中,可以通过定义回调函数来对请求的结果进行处理,回调函数会在请求完成后执行,通过这种方式可以更新页面内容或者响应用户操作。

  2. 我们需要使用 open() 方法打开一个请求,该方法会初始化一个请求,但并不会发送请求。它有三个必填参数以及一个可选参数

    • method:请求的 HTTP 方法,例如 GET、POST 等。
    • url:请求的 URL 地址。
    • async:是否异步处理请求,默认为 true,即异步请求。
  3. onreadystatechange 一个回调函数,在每次状态发生变化时被调用

    • readyState 0:未初始化,XMLHttpRequest 对象已经创建,但未调用 open 方法。
    • readyState 1:已打开,open 方法已经被调用,但 send 方法未被调用。
    • readyState 2:已发送,send 方法已经被调用,请求已经被服务器接收。
    • readyState 3:正在接收,服务器正在处理请求并返回数据。
    • readyState 4:完成,服务器已经完成了数据传输。
  4. send 向后端传递参数 例如 xhe.send(params)

3. ajax 发送请求示例

在 XMLHttpRequest 对象中,onload 事件是指在 AJAX 请求成功完成后所触发的事件。当异步请求成功返回响应时,该事件会被调用,可以在该事件中处理服务器返回的数据。

使用 XMLHttpRequest 对象时,在调用 send() 方法发送请求后,会监听 readystatechange 事件,该事件会在请求过程中多次触发,它有多个状态,其中,当该对象 readyState 状态码值为 4 时表示已经获取到服务器的响应信息。但是只有当 HTTP 状态码为 200(OK)时,响应才是有效的。此时,你可以通过响应结果来更新页面,反之则应该进行错误处理。

使用 onload 事件可以更加直接地判断 AJAX 请求是否成功,只有在响应成功(即获得正确的 HTTP 状态码)时才会触发,并且无需判断服务器响应的状态码。可以在 onload 事件中处理服务器返回的数据,并根据需要更新网页内容。

3.1 发送 get 请求

const xhr = new XMLHttpRequest();
xhr.open("GET", "http://localhost:3000/api/txt");
xhr.onload = function () {if (xhr.status === 200) {document.querySelector("#result").innerText = xhr.responseText;} else {console.log("Request failed.  Returned status of " + xhr.status);}
};
xhr.send(null);

3.2 发送 post 请求 application/json

const xhr = new XMLHttpRequest();
xhr.open("POST", "http://localhost:3000/api/post");
xhr.setRequestHeader("Content-Type", "application/json");
xhr.onload = function () {if (xhr.status === 200) {document.querySelector("#result").innerText = xhr.responseText;} else {console.log("Request failed.  Returned status of " + xhr.status);}
};
xhr.send(JSON.stringify({ name: "zhangsan", age: 18 }));

3.3 发送 post 请求 application/x-www-form-urlencoded

const xhr = new XMLHttpRequest();
xhr.open("POST", "http://localhost:3000/api/post");
xhr.setRequestHeader("Content-Type", "application/x-www-form-urlencoded");
xhr.onload = function () {if (xhr.status === 200) {document.querySelector("#result").innerText = xhr.responseText;} else {console.log("Request failed.  Returned status of " + xhr.status);}
};
xhr.send("name=zhangsan&age=18");

3.4 上传图片 multipart/form-data

使用 FormData 设置参数

浏览器会自动设置请求头为 multipart/form-data

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-d6bYWOxr-1690338871942)(image.png)]

并且浏览器会自动添加 boundary 分割线

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-h2olgBgJ-1690338871943)(image-1.png)]

document.querySelector("#file").addEventListener("change", function () {const xhr = new XMLHttpRequest();xhr.open("POST", "http://localhost:3000/api/upload");xhr.onload = function () {if (xhr.status === 200) {document.querySelector("#result").innerText = xhr.responseText;} else {console.log("Request failed.  Returned status of " + xhr.status);}};let file = this.files[0];let formData = new FormData();formData.append("file", file);xhr.send(formData);
});

4. 中断请求和设置超时时间

  1. 中断请求: xhr.abort();, 并且会有一个中断的回调
xhr.addEventListener("abort", function (event) {console.log("我被中断了");
});
  1. 设置超时时间: xhr.timeout = 3000;
xhr.addEventListener("timeout", function (event) {console.log("超时啦");
});

5. 获取进度 progress

  1. 在监听器中,我们通过 event.loadedevent.total 属性获取已上传数据量和总数据量,并计算上传进度,最后将进度显示在页面上
xhr.addEventListener("progress", function (event) {document.querySelector("#progress").innerText = `${((event.loaded / event.total) *100).toFixed(2)}%`;
});
http://www.yayakq.cn/news/109486/

相关文章:

  • 设计师服务平台台举例说明seo
  • 关于配色的网站推荐烟台h5网站开发
  • 做网站的时候遇到的问题辽宁省城乡建设厅网站
  • 关于设计的网站监理工程师成绩在建设部哪个网站查
  • 南宁公司网站开发阿里云服务器如何实现一个空间绑定两个不同主体的网站
  • 重庆营销网站建设项目网格图
  • 网站设计 做鼠标效果做淘宝店铺装修的公司网站
  • 深圳网站建设计乐清网站制作推荐
  • 济宁住房和城乡建设厅网站wordpress 数据库搜索功能
  • 简述网站开发的几个步骤网站asp源码
  • 基于asp的网络课程网站开发三个小伙毕业了做购物网站的电视剧
  • 网站防止挂马应该怎么做seo诊断大夫
  • 工程造价询价网站四川建设厅的网站
  • 租房信息网站建设哪个网上购物网站好
  • 电商设计网站有哪些沈阳营销型网站开发
  • 如何创建一个网址seo黑帽优化
  • 厦门网站开发公司哪家好旅游网页代码模板
  • 阿里云域名注册好后怎么建设网站phpcms v9 网站建设入门
  • 东莞整合网站建设开发外贸移动商城网站建设
  • 利用网上菜谱做网站黑龙江省建设工程质量协会网站
  • 网站开发常用语言总结低成本做网站 百知
  • 云建网站域名注册和网站建设
  • 手机自建网站西安网站策划设计
  • 提升网站的访问速度网站英文转换中文版
  • 网站三大要素是什么意思网站开发步骤需求分析
  • 网站遭攻击郑州pc网站建设
  • nodejs做网站能保护源代码吗国内知名企业网站
  • php开发企业网站教程wordpress音乐播放器代码
  • 影视文化网站建设腾讯云申请域名
  • 饰品公司网站建设方案深圳网站开发招聘