AJAX笔记原理篇
黑马程序员视频地址:
AJAX-Day03-01.XMLHttpRequest_基本使用https://www.bilibili.com/video/BV1MN411y7pw?vd_source=0a2d366696f87e241adc64419bf12cab&spm_id_from=333.788.videopod.episodes&p=33https://www.bilibili.com/video/BV1MN411y7pw?vd_source=0a2d366696f87e241adc64419bf12cab&spm_id_from=333.788.videopod.episodes&p=33
XMLHttpRequest
基本使用方法
//第一步:创建 XMLHttpRequest 对象const xhr = new XMLHttpRequest()//第二步:配置请求方法和请求 url 地址xhr.open("GET", "https://hmajax.itheima.net/api/province")//第三步:监听 loadend 事件,接收响应结果xhr.addEventListener("loadend", () => {//响应结果console.log(xhr.response)//得到的是字符串const object = JSON.parse(xhr.response) //字符串转对象console.log(object)})//第四步:发起请求xhr.send()
查询参数
//第二步:配置请求方法和请求 url 地址xhr.open("GET", "https://hmajax.itheima.net/api/area?pname=辽宁省&cname=大连市")
将 对象 快速转成 参数1=值1&参数2=值2... 的字符串格式
//获取输入框的值const pname = document.querySelector(".province").valueconst cname = document.querySelector(".city").value//构建对象 (输入框数量多时,用serialiaze函数快速获取,得到的结果是对象,就可以直接使用)const valueObj = {pname,cname}//⭐️查询参数对象转成查询参数字符串const paramsObj = new URLSearchParams(valueObj)const queryString = paramsObj.toString()//创建XMR对象const xhr = new XMLHttpRequest()//配置参数xhr.open("GET", `https://hmajax.itheima.net/api/area?${queryString}`)//配置监听事件xhr.addEventListener("loadend", () => {console.log(xhr.response)})//发送请求xhr.send()
数据提交
document.querySelector('.reg-btn').addEventListener('click', () => {//创建请求体实例对象const xhr = new XMLHttpRequest()//设置参数xhr.open("POST", "https://hmajax.itheima.net/api/register")//设置监听时间xhr.addEventListener("loadend", () => {console.log(xhr.response)})//⭐️设置请求头-告诉服务器数据类型xhr.setRequestHeader("Content-Type", "application/json")//准备提交的数据const userObj = {username: "admin123",password: "12345678"}const userStr = JSON.stringify(userObj)//设置请求体,发送请求xhr.send(userStr)})
Promise
基本使用方法
//创建Promise对象const p = new Promise((resolve, reject) => {//执行异步任务-并传递结果//如果此处调用了resolve(),则接下来会让then()执行//如果此处调用了reject(),则接下来会让catch()执行})p.then(result => {//成功执行})p.catch(error => {//失败执行})
promise的三种状态
XHR与Promise联合使用
const p = new Promise((resolve, reject) => {//创建XHR对象const xhr = new XMLHttpRequest()//设置参数xhr.open("GET", "https://hmajax.itheima.net/api/province123")//设置监听事件xhr.addEventListener("loadend", () => {//可以打印一下xhr对象看一下数据if(xhr.status >= 200 && xhr.status <= 300){//成功,调用resolve()让其自动调用then()resolve(JSON.parse(xhr.response))}else{//失败,调用reject()让其自动调用catch()reject(new Error(xhr.response))}})//发送请求体xhr.send()}).then(result => {//成功执行console.log(result)}).catch(error => {//失败执行,错误要用dir打印console.dir(error)})
dir打印结果
封装简易版axios
简陋版(简单GET获取,不需要传参)
//封装函数function myAxios(object){return new Promise((resolve, reject) => {//创建XHR对象const xhr = new XMLHttpRequest()//设置属性xhr.open(object.method || "GET", object.url)//设置监听事件xhr.addEventListener("loadend", () => {if(xhr.status >= 200 && xhr.status < 300){//成功resolve(JSON.parse(xhr.response))}else{//失败reject(new Error(xhr.response))}})//发送请求体xhr.send()})}//调用myAxios({url: "https://hmajax.itheima.net/api/province"}).then(result => {console.log(result)}).catch(error => {console.log(error)})
完整版(GET/POST都可以用,可以携带参数)
//封装函数
function myAxios(object){return new Promise((resolve, reject) => {//创建XHR对象const xhr = new XMLHttpRequest()//设置属性if(obj.params){object.url += "?" + new URLSearchParams(object.params).toString()}xhr.open(object.method || "GET", object.url)//设置监听事件xhr.addEventListener("loadend", () => {if(xhr.status >= 200 && xhr.status < 300){//成功resolve(JSON.parse(xhr.response))}else{//失败reject(new Error(xhr.response))}})//判断是否有data选项if(object.data){//设置请求头xhr.setRequestHeader("Content-Type", "application/json")const strdata = JSON.stringify(object.data)//发送请求体xhr.send(strdata)}else{//发送请求体xhr.send()}})}//调用(用户注册)
myAxios({url: "https://hmajax.itheima.net/api/register",method: "POST",data: {username: "usera_001",password: "usera_001"}}).then(result => {console.log(result)}).catch(error => {console.log(error)})
案例:获取天气预报
function getWeather(cityCode) //封装获取天气函数
{myAxios({url: "https://hmajax.itheima.net/api/weather",params: {city: cityCode}}).then(result => {const weatherData = result.datafor(let k in weatherData){if(k === "data"){}else if(k === "dayForecast"){const weatherList = weatherData[k].map(item => {return`<li class="item"> <div class="date-box"> <span class="dateFormat">${item.dateFormat}</span> <span class="date">${item.date}</span> </div> <img src="${item.weatherImg}" alt="" class="weatherImg"> <span class="weather">${item.weather}</span> <div class="temp"> <span class="temNight">${item.temNight}</span>- <span class="temDay">${item.temDay}</span> <span>℃</span> </div> <div class="wind"> <span class="windDirection">${item.windDirection}</span> <span class="windPower"><${item.windPower}</span> </div> </li>`})document.querySelector(".week-wrap").innerHTML = weatherList.join("")}else if(k === "todayWeather"){document.querySelector(".today-weather").innerHTML = `<div class="range-box"><span>今天:</span><span class="range"><span class="weather">${weatherData[k].weather}</span><span class="temNight">${weatherData[k].temNight}</span><span>-</span><span class="temDay">${weatherData[k].temDay}</span><span>℃</span></span></div><ul class="sun-list"><li><span>紫外线</span><span class="ultraviolet">${weatherData[k].ultraviolet}</span></li><li><span>湿度</span><span class="humidity">${weatherData[k].humidity}</span>%</li><li><span>日出</span><span class="sunriseTime">${weatherData[k].sunriseTime}</span></li><li><span>日落</span><span class="sunsetTime">${weatherData[k].sunsetTime}</span></li></ul>`}else if(k === "weatherImg"){document.querySelector(`.${k}`).src = weatherData[k]}else{document.querySelector(`.${k}`).innerText = weatherData[k]}}}).catch(error => {console.log(error)})
}getWeather("110111") //默认获取北京天气document.querySelector(".search-city").addEventListener("input", e => { //输入字符实时搜索城并返回列表myAxios({url: "https://hmajax.itheima.net/api/weather/city",params: {city: e.target.value}}).then(result => {document.querySelector(".search-list").innerHTML = result.data.map(item => {return `<li class="city-item" data-cityCode = "${item.code}">${item.name}</li>`}).join("")})
})document.querySelector(".search-list").addEventListener("click", e => { //列表点击再次搜索if(e.target.classList.contains("city-item")){getWeather(e.target.dataset.citycode)}
})
相关文章:

AJAX笔记原理篇
黑马程序员视频地址: AJAX-Day03-01.XMLHttpRequest_基本使用https://www.bilibili.com/video/BV1MN411y7pw?vd_source0a2d366696f87e241adc64419bf12cab&spm_id_from333.788.videopod.episodes&p33https://www.bilibili.com/video/BV1MN411y7pw?vd_sour…...
ubuntu直接运行arm环境qemu-arm-static
qemu-arm-static 嵌入式开发有时会在ARM设备上使用ubuntu文件系统。开发者常常会面临这样一个问题,想预先交叉编译并安装一些应用程序,但是交叉编译的环境配置以及依赖包的安装十分繁琐,并且容易出错。想直接在目标板上进行编译和安装&#x…...

尝试把clang-tidy集成到AWTK项目
前言 项目经过一段时间的耕耘终于进入了团队开发阶段,期间出现了很多问题,其中一个就是开会讨论团队的代码风格规范,目前项目代码风格比较混乱,有的模块是驼峰,有的模块是匈牙利,后面经过讨论,…...
一文了解性能优化的方法
背景 在应用上线后,用户感知较明显的,除了功能满足需求之外,再者就是程序的性能了。因此,在日常开发中,我们除了满足基本的功能之外,还应该考虑性能因素。关注并可以优化程序性能,也是体现开发能…...
【怎么用系列】短视频戒断——对推荐算法进行干扰
如今推荐算法已经渗透到人们生活的方方面面,尤其是抖音等短视频核心就是推荐算法。 【短视频的危害】 1> 会让人变笨,慢慢让人丧失注意力与专注力 2> 让人丧失阅读长文的能力 3> 让人沉浸在一个又一个快感与嗨点当中。当我们刷短视频时&#x…...
C#中的委托(Delegate)
什么是委托? 首先,我们要知道C#是一种强类型的编程语言,强类型的编程语言的特性,是所有的东西都是特定的类型 委托是一种存储函数的引用类型,就像我们定义的一个 string str 一样,这个 str 变量就是 string 类型. 因为C#中没有函数类型,但是可以定义一个委托类型,把这个函数…...

PostCss
什么是 PostCss 如果把 CSS 单独拎出来看,光是样式本身,就有很多事情要处理。 既然有这么多事情要处理,何不把这些事情集中到一起统一处理呢? PostCss 就是基于这样的理念出现的。 PostCss 类似于一个编译器,可以将…...
Linux 系统上安装 Docker 并进行配置
Docker 是一种开源的应用容器引擎,它允许开发者打包他们的应用以及应用的依赖包到一个可移植的容器中,然后发布到任何流行的 Linux 机器上,也可以实现虚拟化。容器是完全使用沙箱机制,相互之间不会有任何接口(类似 iPh…...
DeepSeek 等 AI 技术能否推动股市的繁荣?
在科技浪潮汹涌澎湃的当下,DeepSeek 等 AI 技术宛如闪耀在天际的耀眼星辰,吸引着全球各界的高度关注。面对这些前沿技术,投资者和市场参与者心中不禁泛起疑问:它们是否能成为推动股市繁荣的强劲动力?这一问题不仅左右着…...

【网络】应用层协议http
文章目录 1. 关于http协议2. 认识URL3. http协议请求与响应格式3.1 请求3.2 响应 3. http的常见方法4. 状态码4.1 常见状态码4.2 重定向 5. Cookie与Session5.1 Cookie5.1.1 认识Cookie5.1.2 设置Cookie5.1.3 Cookie的生命周期 5.2 Session 6. HTTP版本(了解&#x…...

大数据数仓实战项目(离线数仓+实时数仓)2
1.课程目标和课程内容介绍 2.数仓维度建模设计 3.数仓为什么要分层 4.数仓分层思想和作用 下面是阿里的一种分层方式 5.数仓中表的种类和同步策略 6.数仓中表字段介绍以及表关系梳理 订单表itcast_orders 订单明细表 itcast_order_goods 商品信息表 itcast_goods 店铺表 itcast…...

测试csdn图片发布
测试csdn图片发布 ...

站在JavaScript的视角去看,HTML的DOM和GLTF的Json数据。
很多前端小伙伴没有见过、操作过gltf文件,对非常懵逼,本文从前端小伙伴最熟悉的dom模型为切入口,以类别的方式来学习一下gltf文件。 一、结构与组织形式 HTML DOM(文档对象模型): 树形结构:HT…...

传输层协议 UDP 与 TCP
🌈 个人主页:Zfox_ 🔥 系列专栏:Linux 目录 一:🔥 前置复盘🦋 传输层🦋 再谈端口号🦋 端口号范围划分🦋 认识知名端口号 (Well-Know Port Number) 二…...
VSCode源码分析参考资料
VSCode Architecture Analysis - Electron Project Cross-Platform Best Practices 中文版 VSCode 架构分析 - Electron 项目跨平台最佳实践 Sihan Li博客上的vscode源码分析系列:分析了微服务架构、事件体系、资源管理、配置系统等 文召博客上的vscode 源码解析…...

使用VCS对Verilog/System Verilog进行单步调试的步骤
Verilog单步调试: System Verilog进行单步调试的步骤如下: 1. 编译设计 使用-debug_all或-debug_pp选项编译设计,生成调试信息。 我的4个文件: 1.led.v module led(input clk,input rst_n,output reg led );reg [7:0] cnt;alwa…...

ROS-激光雷达-消息包格式-获取激光雷达数据-激光雷达避障
文章目录 激光雷达原理 消息包格式获取激光雷达数据激光雷达避障 激光雷达 原理 激光雷达(LiDAR) 是一种利用激光进行距离测量和环境感知的传感器。它通过发射激光束并接收反射光来测量物体的距离,生成点云数据,用于构建环境的三…...

c++之模板进阶
在前面的文章中,我们已经简单的了解了模板的使用,在这篇文章中,我们将继续深入探讨模板 1.模板的特化 1.1 概念 通常情况下,使用模板可以实现一些与类型无关的代码,但对于一些特殊类型的可能会得到一些错误的结果&a…...

关于Internet Download Manager(IDM)强制下载合并相关二次开发
目录 前言 强制下载视频 强制合并 迁移下载列表 免责声明 附录 前言 那个下载工具IDM不说了,确实有很多便捷的功能,不过也有一些限制 常见的包括但不限于: 1.无法下载有版权保护的视频(不管真假) 2.有时候下载…...
鸿蒙HarmonyOS Next 视频边播放边缓存- OhosVideoCache
OhosVideoCache 是一个专为OpenHarmony开发(HarmonyOS也可以用)的音视频缓存库,旨在帮助开发者轻松实现音视频的边播放边缓存功能。以下是关于 OhosVideoCache 的详细介绍: 1. 核心功能 边播放边缓存:将音视频URL传递给 OhosVideoCache 处理后…...

聊聊 Pulsar:Producer 源码解析
一、前言 Apache Pulsar 是一个企业级的开源分布式消息传递平台,以其高性能、可扩展性和存储计算分离架构在消息队列和流处理领域独树一帜。在 Pulsar 的核心架构中,Producer(生产者) 是连接客户端应用与消息队列的第一步。生产者…...

【大模型RAG】Docker 一键部署 Milvus 完整攻略
本文概要 Milvus 2.5 Stand-alone 版可通过 Docker 在几分钟内完成安装;只需暴露 19530(gRPC)与 9091(HTTP/WebUI)两个端口,即可让本地电脑通过 PyMilvus 或浏览器访问远程 Linux 服务器上的 Milvus。下面…...

Java-41 深入浅出 Spring - 声明式事务的支持 事务配置 XML模式 XML+注解模式
点一下关注吧!!!非常感谢!!持续更新!!! 🚀 AI篇持续更新中!(长期更新) 目前2025年06月05日更新到: AI炼丹日志-28 - Aud…...
解决本地部署 SmolVLM2 大语言模型运行 flash-attn 报错
出现的问题 安装 flash-attn 会一直卡在 build 那一步或者运行报错 解决办法 是因为你安装的 flash-attn 版本没有对应上,所以报错,到 https://github.com/Dao-AILab/flash-attention/releases 下载对应版本,cu、torch、cp 的版本一定要对…...
鸿蒙中用HarmonyOS SDK应用服务 HarmonyOS5开发一个生活电费的缴纳和查询小程序
一、项目初始化与配置 1. 创建项目 ohpm init harmony/utility-payment-app 2. 配置权限 // module.json5 {"requestPermissions": [{"name": "ohos.permission.INTERNET"},{"name": "ohos.permission.GET_NETWORK_INFO"…...

dify打造数据可视化图表
一、概述 在日常工作和学习中,我们经常需要和数据打交道。无论是分析报告、项目展示,还是简单的数据洞察,一个清晰直观的图表,往往能胜过千言万语。 一款能让数据可视化变得超级简单的 MCP Server,由蚂蚁集团 AntV 团队…...
动态 Web 开发技术入门篇
一、HTTP 协议核心 1.1 HTTP 基础 协议全称 :HyperText Transfer Protocol(超文本传输协议) 默认端口 :HTTP 使用 80 端口,HTTPS 使用 443 端口。 请求方法 : GET :用于获取资源,…...

何谓AI编程【02】AI编程官网以优雅草星云智控为例建设实践-完善顶部-建立各项子页-调整排版-优雅草卓伊凡
何谓AI编程【02】AI编程官网以优雅草星云智控为例建设实践-完善顶部-建立各项子页-调整排版-优雅草卓伊凡 背景 我们以建设星云智控官网来做AI编程实践,很多人以为AI已经强大到不需要程序员了,其实不是,AI更加需要程序员,普通人…...

MySQL体系架构解析(三):MySQL目录与启动配置全解析
MySQL中的目录和文件 bin目录 在 MySQL 的安装目录下有一个特别重要的 bin 目录,这个目录下存放着许多可执行文件。与其他系统的可执行文件类似,这些可执行文件都是与服务器和客户端程序相关的。 启动MySQL服务器程序 在 UNIX 系统中,用…...
React父子组件通信:Props怎么用?如何从父组件向子组件传递数据?
系列回顾: 在上一篇《React核心概念:State是什么?》中,我们学习了如何使用useState让一个组件拥有自己的内部数据(State),并通过一个计数器案例,实现了组件的自我更新。这很棒&#…...