ajax最大的优点是在不重新加载整个页面的情况下,可以与服务器交换数据并更新部分网页的内容

ajax指是一种创建交互式网页应用的网页开发技术,其实就是实现前后端交互。

1)ajax是异步javascript,异步的意思即非阻塞,就像线程,在代码运行到ajax请求时,它会分成两条线,一条线去运行ajax请求里面的内容,另一条线去运行主程序(即ajax请求后面的代码),当然我们可以因需要异步设置成同步(即在运行到ajax请求时,将阻塞运行完ajax请求后,再去运行ajax外,后面的代码)

2)注意ajax请求是由jquery发起的,因此用于jquery代码块中。

3)执行相应的视图函数(这里是在一个py,php等文件创建一个视图函数,或者class类,给这个视图函数分级设置一个url地址,ajax请求中的url即填写完整的url地址),返回json内容。

4)执行相应的回调函数(即返回成功后的执行success里面的 js,jquery去影响web页面),通过判断 json 内容,进行相应的处理。

ajax不需要任何浏览器插件

现在我们搭建一个服务器环境,为什么要搭建服务器环境呢?因为ajax请求一般都是需要服务器调用数据库。现在这里有个比较方便的软件  -- wampserver

这个wampsever就是在window下的apache、php和mysql的服务器软件

这里我们需要安装wampsever  安装过程的具体步骤自己在百度中找教程(最好不要安装在C盘,找个内存多一点的盘安装)

在安装的文件夹中找一个www的文件夹,www文件就是网站内容所在区域    本地IP:127.0.0.1 端口号80  本地域名locolhost

在pycharm中open打开www文件,在此文件中写html,css,js,php等。

ajax要有后台服务器,可以用java,python,php搭建一个后台服务器。

写前端html文件的时候的用法:$.ajax({    })。$.ajax是所有ajax方法中最底层的方法。所有其他的方法都是基于$.ajax()方法的封装。

此方法中的参数有:(这里只写了一部分)注意都要用引号引住。

参数 类型 说明
url   为string(因此要用引号引起来) 发送请求的地址
 type string 请求的方式:post或get请求。默认为get请求
data Object或string 发送服务器的数据,键值对,字符串或对象,这里post请求有此参数,get请求直接在地址处?后面传参即可
dataType string 后端返回给前端的数据类型,比如html,xml,json。本来是string,在ajax请求时设置dataType为json,将字符串;类型变为json类型
success function 请求成功后调用的回调函数,需要操作的东西一般在这里写    用法success:function(e 这个字母e可以是其他英文){写内容}    注意这个()里面的e或者说其他东西就是后端HttpResponse或者JsonResponse返回的东西,这里与dataType有关
error function 请求失败时调用的回调函数
async Boolean 是否异步处理,默认为True,false为同步处理

post请求中参数data的两种写法:

1)“后端要接收的参数名=”+前端某个input的 val()或value值+“&后端要接收的参数名=”+前端的input中的值    例>>>

2)字典传参    {“后端要接收的参数名”:前端某个input的 val()或value值  ,"后端要接收的参数名":前端的input中的值 }    例>>>

get请求中前端向后端传参的方法:

在post请求进行前后端数据的交换,python后端 request.POST.get(“前端给后端要接收的参数在data时起名,如上 un 和 pa ”)  接收前端的数据,当然这是对POST请求时的接收方式,get请求时,则将POST改为GET即可。

这里就是后端接收上图前端数据的方法  

下图是实现前后端交互时前端需要的操作,这里还设置了同步

另外我们可以直接  0$.get()  或  $.post()

先说$.get()请求  (参数之间用逗号隔开)

第一个参数:请求的接口,即要访问的地址

第二个参数:请求接口时携带的参数  可以是字典的形式传参      

      或者这样传参:

第三个参数:接口请求成功后的回调参数,即原本$.ajax()中的success后面的function()

第四个参数:接口返回的数据类型,即设置后端返回给前端返回的数据类型,本来不管后端返回是HttpResponse或者JsonResponse,没有前端这个参数都会显示后端返回的是字符串类型,有了这个参数,就可以使字符串变成该有的形式,比如这里写“json”,后端传的数据就变成了 json 类型

$.post()的相关用法:(跟$.get()的用法类似)

第一个参数:请求的接口,即要访问的地址

第二个参数:请求接口时携带的参数  可以是字典的形式传参

第三个参数:接口请求成功后的回调参数,即原本$.ajax()中的success后面的function()

现在我们先讲一下用php做一个后台服务器(这里为什么先讲一下用php做后台服务器呢?因为用python做后台服务器需要的东西有点多,暂且先拿php用一下)

写php文件:在www中新创建一个file文档>>>此文档以  <?php  开头 ,以  ?>  结尾。第一个注意点运行此文件时要开启wampsever软件

php有一个名句--遍地是黄金。  变量都是由$为开头的。

第一步:在php文件中获取前端传递过来的数据。这里注意在php文件中的变量名由$开头的变量名,前端是post请求则在获取的时候$_POST获取,前端是get请求则用$_GET获取(方法例下--$name=$_POST['在前端传递来的数据'])

第二步:在数据库中查询(这里先不写)

第三步:根据数据库查询的结果不同,返回给前端不同的数据。

第四个参数:接口返回的数据类型。

还有一个知识点:你发现在jquery中收集表单中的数据时,需要对每个标签$()   ,这里有个快速收集表单提交的数据的方法

serializeArray()可以很方便的收集表单里面的数据      例如  这里表单有id属性可以$('input'),也可以$("#register").serializeArray()收集表单数据

收集的数据为 [{},{},...]   (列表嵌套字典的形式)类型

还有一个ajax中涉及到的知识点:跨域

什么是跨域呢?比如说自己懒得弄接口了,去网上找个现成的,(比如要在前端弄个天气预报板块,自己不写后端,直接用网上免费的一些网站)。

例如 >>>  在wampserver中浏览器输入 127.0.0.1:80 和 输入localhost:80 都能打开wampserver的www文件(wampserver的首页),127.0.0.1是它的ip地址 ,localhost是它的域名。但在浏览器下访问的是127.0.0.1,而ajax请求的是localhost时,会报错。

这时我们只需在后端写下下面两个代码即可实现跨域:

ajax--实现异步请求,接受响应及执行回调的更多相关文章

  1. 掌握 Ajax,第 2 部分: 使用 JavaScript 和 Ajax 发出异步请求

    转http://www.ibm.com/developerworks/cn/xml/wa-ajaxintro2/ 掌握 Ajax,第 2 部分: 使用 JavaScript 和 Ajax 发出异步请求 ...

  2. AJAX发送异步请求教程详解

    AJAX 一.AJAX简介 什么是 AJAX ? AJAX = 异步 JavaScript 和 XML. AJAX 是一种用于创建快速动态网页的技术. 通过在后台与服务器进行少量数据交换,AJAX 可 ...

  3. MVC的Ajax的异步请求

    MVC的Ajax的异步请求 在这里小写一下MVC的异步请求的一点小总结. 个人认为是有两种的,一种就是跟webform一样的,依旧是使用jQuery的$.get()方法,只是请求地址不同,webfor ...

  4. AJAX的来龙去脉(由来)-如何被封装出来的--ajax发送异步请求(四步操作)

    <黑马程序员_超全面的JavaWeb视频教程vedio\JavaWeb视频教程_day23_ajax> \JavaWeb视频教程_day23_ajax\day23ajax_avi\14.打 ...

  5. ajax 实现异步请求

    ajax实现异步请求: function onclicks() { $.ajax( { url:'../hhh/columnSearch.do',// 跳转到 action // data: {tab ...

  6. 利用Ajax实现异步请求

    Ajax 1.课程引入      静态网站和动态网站都是同步的,但同步方式有缺点:页面请求响应式阻塞,影响用户体验      为了解决这个问题,可以通过变通的手段实现页面的局部更新(隐藏帧),由于隐藏 ...

  7. ajax json 异步请求

    function ajaxTest(){ if (true) { $.ajaxSettings.async = false; var dataJson; $.getJSON("/univer ...

  8. ajax的异步请求小结

    如何判断是使用json还是jsp的数据传输: json字符串可以使用js,jquery,ajax,java这几种技术,页面为jsp页面,json数据为java后台传递来. 1.同步请求可以从因特网请求 ...

  9. JQ+AJAX 发送异步请求

    1. load() ; 作用:通过ajax 请求从服务器加载数据,并添加到符合要求的节点上 用法:$node.load(请求地址,请求参数) 请求参数写法: --"username=admi ...

随机推荐

  1. go mod管理 init 和 包导入的关系

    你创建了一个文件的名字为:lisi001 如果你初始化项目名字为lisi, go mod init lisi 那么你导包的时候就得也用lisi import ( "lisi/path&quo ...

  2. jQuery实现游戏推荐

    1.需求:点击添加游戏按钮实现添加游戏,点击删除按钮,删除游戏. 2.实现思路:分别给添加按钮和删除按钮添加click事件. 3.遇到的问题:自己添加的游戏不能进行删除. 4.原因分析:文档加载完毕后 ...

  3. Magicodes.IE Excel合并行数据导入教程

    说明 Magicodes.IE.Excel目前已支持合并行单元格导入,如本篇教程所示. 安装包Magicodes.IE.Excel Install-Package Magicodes.IE.Excel ...

  4. 树莓派 3/4 安装 FreeBSD

    已盼春来归 已盼春来归 今日去 愿为春来归 盼归春天来了 FreeBSD 的春天在哪里? 树莓派是什么,相信凡是关注了我们的人都不会不知道,但是介于非专业人员需要在此做简要介绍.我们的安卓手机,大部分 ...

  5. ClickHouse元数据异常-MySQLHandlerFactory:Failed to read RSA key pair from server

    Clickhouse版本:20.3.6.40-2 clickhouse集群三个节点,一分片,三副本,三个节点数据完全一样 1. 问题描述 在使用连接工具操作时,发现其中一个节点连接拒绝,无法操作,另外 ...

  6. ElementUI Tree控件在懒加载模式下的重新加载和模糊查询

    之所以使用懒加载是为了提高性能,而且只有在懒加载模式下默认会给所有显示节点设置展开按钮.leaf也可以做到,但是要操作数据比较麻烦. 要实现懒加载模式下的模糊查询以及重新加载必须要使用data与laz ...

  7. 【LeetCode】52. N-Queens II(位运算)

    [题意] 输出N皇后问题的解法个数. [题解] 解法一:传统dfs回溯,模拟Q放置的位置即可,应该不难,虽然能通过,但是时间复杂度很高. 解法二:位运算大法好! 首先要明白这道题里两个核心的位运算 1 ...

  8. DNA序列(JAVA语言)

    package 第三章习题; /*  * 输入m个长度均为n的DNA序列,求一个DNA序列,到所有序列的总Hamming距离尽量小.  * 两个等长字符串的Hamming距离等于字符不同的位置个数, ...

  9. 10 分钟轻松学会 Jackson 反序列化自动适配子类

    作者:丁仪 来源:https://chengxuzhixin.com/blog/post/Jackson-fan-xu-lie-hua-zi-dong-shi-pei-zi-lei.html json ...

  10. vscode配置c\c++环境

    目录 一.安装vscode 二.安装插件以及配置c\c++编译环境 1. 安装以下两个插件 2. 配置编译环境 一.安装mingw64(推荐) 方法一 方法二 二.如果你安装过visual studi ...