【jquery Ajax】基础概念与使用教学

简介: 【jquery Ajax】基础概念与使用教学

 客户端与服务器

       服务器

上网过程中,负责存放和对外提供资源的电脑,叫做服务器。

image.gif编辑

        客户端

上网过程中,负责获取和消费资源的电脑,叫做客户端,

image.gif编辑

URL地址

       url地址的概念

URL,中文叫统一资源定位符,用于标识互联网上每个资源的唯一存放位置,浏览器只有通过URL地址,才能正确等位资源的存放位置,从而成功访问到对应的资源。

       URL地址的组成部分

URL地址一共分为三部分

    1. 客户端与服务器之间的通信协议
    2. 存有该资源的服务器名称
    3. 资源在服务器上具体的存放位置。

    image.gif编辑 客户端与服务器的通信过程

           过程解释

    客户端

      1. 打开浏览器
      2. 输入要访问的网站地址
      3. 回车,向服务器索要数据内容

      web服务器

        1. 服务器接受到客户端发来的资源请求
        2. 服务器在内部处理这次请求,找到相关的资源
        3. 服务器把找到的资源,响应(发送)给客户端

        image.gif编辑

        客户端与服务器之间每一个资源的通信过程,分为请求——处理——响应三个步骤

        服务器对外都提供了哪些资源

               网页中常见的资源

        image.gif编辑

        数据也是资源

        网页中的数据,也是服务器对外提供的一种资源,例如股票数据,以及排行榜等

          • HTML是网页的骨架
          • CSS是网页的颜值
          • Javascript是网页的行为
          • 数据 则是网页的灵魂

                  网页中如何请求数据

          如果要在网页中请求服务起上的数据资源,则需要用到XMLHttpRequest对象。

          XMLHttpRequest(简称xhr)是浏览器提供的js成员,通过它,可以请求服务器上的数据资源。

          var xhrObj = new XMLHttpRequest()

          image.gif

                 资源的请求方式

          客户端请求服务器时,请求的方式有很多种,最常见的两种请求方式分别为get和post请求。

            • get请求通常用于获取服务端资源(向服务器要资源)
              例如:根据URL地址,从服务器获取HTML文件,css文件,js文件,图片文件,数据资源等
            • post请求通常用于向服务器提交数据(向服务器发送数据)
              例如:登录时向服务器提交的登录信息,注册时向服务器提交的注册信息,添加用户时向服务器提交的用户信息等各种数据提交操作

            了解Ajax

                   什么是Ajax

            Ajax的全称是Asynchronous Javascript And XML(异步 jJavaScript和XML)

            通俗的理解:在网页中利用XMLHttpRequest对象和服务器进行数据交互的方式,就是Ajax

                   为什么要学Ajax

            之前所学的技术,只能把网页做的更美观漂亮,或添加一些动画效果,但是,Ajax能让我们轻松实现网页与服务器之间的数据交互。

            image.gif编辑

                   Ajax的典型应用场景

              1. 用户名检测:注册用户时,通过ajax传送数据,到服务器,进行判断检测用户名是否被占用
                image.gif编辑
              2. 搜索提示:当输入搜索关键字时,通过ajax的形式,动态加载搜索提示列表
                image.gif编辑
              3. 数据分页显示:当点击页码值的时候,通过ajax的形式,根据页码值动态刷新表格的数据(局部刷新)
                image.gif编辑

              了解jquery中的Ajax

              浏览器中提供的XMLHttpRequest用法比较复杂,所以jquery对其进行了封装,提供了一系列Ajax相关的函数,极大地降低了Ajax的使用难度。

              jquery中发起Ajax请求最常用的三个方法如下:

                • $.get()   获取数据
                • $.post()  提交数据
                • $.ajax()   综合

                       $.get()函数的语法

                $.get(url,[data],[callback])

                image.gif

                参数名 参数类型 是否必选 说明
                url string 要请求的资源地址
                data object 请求资源期间要携带的参数
                callback function 请求成功时的回调函数

                        $.get()发起不带参数的请求

                使用$.get()函数发起不带参数的请求时,直接提供请求的URL地址和请求成功之后的回调函数即可。

                //记得导入jquery
                <body>
                    <button id="get">发起不带参数的请求</button>
                </body>
                <script>
                    $('#get').on('click', function () {
                        $.get('http://www.liulongbin.top:3006/api/getbooks', function (res) {
                            console.log(res);
                //res是get拿到的数据
                        })
                    })
                </script>

                image.gif

                image.gif编辑

                         $.get()发起带参数的请求

                <body>
                    <button id="get">发起带参数的请求</button>
                </body>
                <script>
                    $('#get').on('click', function () {
                        $.get('http://www.liulongbin.top:3006/api/getbooks', { id: 1 }, function (res) {
                            console.log(res);
                        })
                    })
                </script>

                image.gif

                发起带参数的请求,这个参数就相当于条件获取指定的数据。

                image.gif编辑

                只获取了id:1数据。

                       $.post()函数的语法

                jquery中$.post()函数的功能单一,专门用来发起post请求,从而向服务器提交数据。

                参数名 参数类型 是否必选 说明
                url string 提交数据的地址
                data object 要提交的数据
                callback function 数据提交成功时的回调函数

                        $.post()向服务器提交数据

                <body>
                    <button id="post">发起post请求</button>
                </body>
                <script>
                    $('#post').click(function () {
                        $.post('http://www.liulongbin.top:3006/api/addbook',
                            { bookname: 'ajax', author: '小解同志', publisher: 'CSDN出版社' }
                            , function (res) {
                                console.log(res);
                                //res代表上传响应回来的数据
                            })
                    })
                </script>

                image.gif

                image.gif编辑

                        $.Ajax函数

                               语法

                相比于$.get()和$.post()函数,jquery中提供的$.ajax()函数,是一个功能比较综合的函数,他允许我们队Ajax请求进行更详细的配置。

                image.gif编辑

                                使用$.ajax()发起的get请求

                <body>
                    <button id="get">发布get请求</button>
                </body>
                <script>
                    $('#get').click(function () {
                        $.ajax({
                            type: 'get',
                            url: 'http://www.liulongbin.top:3006/api/getbooks',
                            data: {
                                id: 2
                            },
                            success: function (res) {
                                console.log(res);
                            }
                        })
                    })
                </script>

                image.gif

                image.gif编辑

                                 使用$.ajax()发起的post请求

                <body>
                    <button id="get">发布get请求</button>
                </body>
                <script>
                    $('#get').click(function () {
                        $.ajax({
                            type: 'post',
                            url: 'http://www.liulongbin.top:3006/api/addbook',
                            data: { bookname: 'ajax', author: '小解同志', publisher: 'CSDN出版社' }
                            ,
                            success: function (res) {
                                console.log(res);
                            }
                        })
                    })

                image.gif

                image.gif编辑


                目录
                相关文章
                N..
                |
                8月前
                |
                XML JSON 前端开发
                jQuery实现Ajax
                jQuery实现Ajax
                N..
                79 1
                |
                8月前
                |
                XML 前端开发 JavaScript
                jQuery中ajax如何使用
                jQuery中ajax如何使用
                100 0
                |
                7月前
                |
                前端开发 JavaScript
                杨校老师课堂之基于Servlet整合JQuery中的Ajax进行表单提交[基于IDEA]
                杨校老师课堂之基于Servlet整合JQuery中的Ajax进行表单提交[基于IDEA]
                57 0
                |
                3月前
                |
                前端开发 JavaScript 数据处理
                JQuery 拦截请求 | Ajax 请求拦截
                【10月更文挑战第4天】
                150 1
                |
                4月前
                |
                JSON 前端开发 JavaScript
                jQuery AJAX 方法
                jQuery AJAX 方法
                45 1
                |
                4月前
                |
                JSON JavaScript 前端开发
                Jquery常用操作汇总,dom操作,ajax请求
                本文汇总了jQuery的一些常用操作,包括DOM元素的选择、添加、移除,表单操作,以及如何使用jQuery发送Ajax请求,涵盖了GET、POST请求和文件上传等常见场景。
                |
                4月前
                |
                JSON 前端开发 JavaScript
                jQuery AJAX 方法
                jQuery AJAX 方法
                29 1
                |
                5月前
                |
                前端开发 JavaScript Java
                SpringBoot+JQuery+Ajax实现表单数据传输和单文件或多文件的上传
                关于如何在SpringBoot项目中结合JQuery和Ajax实现表单数据的传输以及单文件或多文件上传的教程。文章提供了完整的前后端示例代码,包括项目的`pom.xml`依赖配置、SpringBoot的启动类`App.java`、静态资源配置`ResourceConfig.java`、配置文件`application.yml`、前端HTML页面(单文件上传和多文件上传加表单内容)以及后端控制器`UserController.java`。文章最后展示了运行结果的截图。
                300 0
                SpringBoot+JQuery+Ajax实现表单数据传输和单文件或多文件的上传
                |
                5月前
                |
                XML JSON 前端开发
                AJAX是什么?原生语法格式?jQuery提供分装好的AJAX有什么区别?
                AJAX是什么?原生语法格式?jQuery提供分装好的AJAX有什么区别?
                39 0
                |
                5月前
                |
                JavaScript 前端开发
                Ajax的使用(jquery的下载)
                这篇文章是关于Ajax学习笔记的分享,包括JQuery的下载方式、Ajax的主要参数说明,以及如何在网页中使用Ajax进行异步请求的示例代码。