AJAX使用

定义:使用XMLHttpRequest对象与服务器通信。

axios库,与服务器进行数据通信,基于XMLHttpRequest封装

语法:

  1. 引入axios.js
  2. 使用axios函数

传入配置对象

在.then回调函数接受结果,进行后续处理

html 复制代码
<script src="https://unpkg.com/axios/dist/axios.min.js"></script>

    <script>

        axios({

            url:'http://hmajax.itheima.net/api/province'

        }).then(result =>{

            console.log(result)

        })

    </script>

hmajax.itheima.net/api/province

数组转字符串<br>

URL:统一资源定位符,网址

组成:协议 http超文本传输协议,https

域名(必须):标记服务器在互联网上的方位

资源路径:标记资源在服务器下的具体路径

url查询参数:浏览器提供给服务器的额外信息,让服务器返回浏览器的想要的数据

url?参数名1=值&参数名2=值

params:{

参数名:值

}

常见请求方法:

post:提交数据,需要把数据提交到服务器中

method:'post'

data:{

参数名:值

}

<button class="mybutton">注册用户</button>

<script src="https://unpkg.com/axios/dist/axios.min.js"></script>

<script>

document.querySelector('.mybutton').addEventListener('click',()=>{

axios({

url:'http://hmajax.itheima.net/api/register',

method:'post',

data:{

username:'12341524',

password:'123454'

}

}).then(result =>{

console.log(result)

document.querySelector('.my-p').innerHTML = result.data.list.join('<br>');

})

})

</script>

axios错误处理

axios({

请求选项

}).then(result=>{

处理数据

}).catch(error=>{

错误处理

})

html 复制代码
 <button class="mybutton">注册用户</button>
    <script src="https://unpkg.com/axios/dist/axios.min.js"></script>
    <script>

        document.querySelector('.mybutton').addEventListener('click',()=>{
            axios({
            url:'http://hmajax.itheima.net/api/register',
            method:'post',
            data:{
                username:'12341524',
                password:'123454'

            }
        }).then(result =>{
           /* console.log(result)
            document.querySelector('.my-p').innerHTML = result.data.list.join('<br>');*/
        }).catch(error=>{
            alert(error.message)
        })
        })
    </script>

查看请求报文以排查错误

http协议------响应报文

接口文档 :描述接口文档

接口:使用Ajax和服务器通讯时,使用的url,请求参数

form-serialize插件:快速手机表单元素的值

引入插件

语法:form哪个表单的数据,表单元素要设置name属性,值会作为对象的属性,建议name的值与接口对象一致

参数二:配置对象

hash设置获取数据结构 ture:json对象 (推荐)false:查询字符串

empty控制是否获取表单中的空值 true:获取空值 false:不获取空值的字段

const data = serialize(form,{hash:true,empty:true})

图片上传(form-data)

  1. 获取图片文件对象
  2. 使用FormData携带图片文件

const fd = new FormData();

fd.append('imag',e.target.files[0])

XMLHttpRequest:对象用于服务器交互

  1. 创建XMLHttpRequest对象 const xml = new XMLHttpRequest()
  2. 配置请求方法和请求url地址 xhr.open('请求方法','请求地址')
  3. 监听loadend事件,接受响应结果xhr.addEventListener('loadend',()=>{

//响应结果

console.log(xhr.response)

})

4.发起请求xhr.send()

javascript 复制代码
const xhr = new XMLHttpRequest();
        xhr.open('GET','http://hmajax.itheima.net/api/province');
        xhr.addEventListener('loadend',()=>{
            console.log(xhr.response)
            const data =JSON.parse(xhr.response)
        });
        xhr.send();

查询参数:提供给服务器的额外信息,让服务器返回浏览器想要的数据

url?参数名1=值&参数名2=值

数据提交:请求体参数(application/json)

  1. 请求体中设置Content-Type:application/json
  2. 请求体携带json字符串

xhr.setRequestHeader('Content-Type','application/json')

const user = {username:'kkk',password:'hihh'}

const userStr = JSON.stringify(user)

xhr.send(userStr)

javascript 复制代码
    const xhr = new XMLHttpRequest();
        xhr.open('POST','http://hmajax.itheima.net/api/register');
        xhr.addEventListener('loadend',()=>{
            console.log(xhr.response)
            const data =JSON.parse(xhr.response)
        });
        xhr.setRequestHeader('Content-Type','application/json');
        const user = {username:'huhuih',password:'1232456'}
        const usetStr = JSON.stringify(user)
        xhr.send(usetStr);
相关推荐
崔庆才丨静觅5 小时前
hCaptcha 验证码图像识别 API 对接教程
前端
passerby60616 小时前
完成前端时间处理的另一块版图
前端·github·web components
掘了6 小时前
「2025 年终总结」在所有失去的人中,我最怀念我自己
前端·后端·年终总结
崔庆才丨静觅6 小时前
实用免费的 Short URL 短链接 API 对接说明
前端
崔庆才丨静觅7 小时前
5分钟快速搭建 AI 平台并用它赚钱!
前端
崔庆才丨静觅7 小时前
比官方便宜一半以上!Midjourney API 申请及使用
前端
Moment7 小时前
富文本编辑器在 AI 时代为什么这么受欢迎
前端·javascript·后端
崔庆才丨静觅8 小时前
刷屏全网的“nano-banana”API接入指南!0.1元/张量产高清创意图,开发者必藏
前端
剪刀石头布啊8 小时前
jwt介绍
前端
爱敲代码的小鱼8 小时前
AJAX(异步交互的技术来实现从服务端中获取数据):
前端·javascript·ajax