zoukankan      html  css  js  c++  java
  • JQuery ajax-向服务器发送请求的方法

    如需将请求发送到服务器,我们使用 XMLHttpRequest 对象的 open() 和 send() 方法:
    xmlhttp.open("GET","ajax_info.txt",true);//打开文件
    xmlhttp.send();// 发送数据
    open(method,url,async):

    规定请求的类型、URL 以及是否异步处理请求。

    • method:请求的类型;GET 或 POST
    • url:文件在服务器上的位置
    • async:true(异步)或 false(同步)
    send(string)
    将请求发送到服务器。
    string:仅用于 POST 请求;
     

    GET 还是 POST?

    与 POST 相比,GET 更简单也更快,并且在大部分情况下都能用。

    然而,在以下情况中,请使用 POST 请求:

    • 无法使用缓存文件(更新服务器上的文件或数据库)
    • 向服务器发送大量数据(POST 没有数据量限制)
    • 发送包含未知字符的用户输入时,POST 比 GET 更稳定也更可靠
     

    语法AJAX方法:

    $.ajax({name:value, name:value, ... })
     1 <!DOCTYPE html>
     2 <htmllang="en">
     3 <head>
     4 <metacharset="UTF-8"/>
     5 <title>Document</title>
     6 </head>
     7 <body>
     8 姓名:<inputtype="text"name="user">
     9 年龄:<inputtype="text"name="age">
    10 <inputtype="button"value="输入">
    11 <divstyle="border:1px solid red;padding:30px">
    12 <h2>你的信息:</h2>
    13 <p>XXX</p>
    14 <p>XXX</p>
    15 </div>
    16 </body>
    17 <scripttype="text/javascript"src="http://apps.bdimg.com/libs/jquery/2.1.4/jquery.min.js"></script>
    18 <scripttype="text/javascript">
    19 var $btn = $("input[type=button]");
    20 var $input = $("input[type=text]");
    21 var $p = $("p");
    22 $btn.on("click",function(){
    23 $.ajax({
    24 type:"get",// 请求方式;
    25 url:"1-jq-ajax-get.php",// 连接服务器数据地址;
    26 data:{name:$input.eq(0).val(), age:$input.eq(1).val()},// 传输的数据
    27 dataType:"json",//传过来的数据类型
    28 success:function(data){
    29 console.log(data);//成功的时候
    30 $p.eq(0).text(data.name);
    31 $p.eq(1).text(data.age);
    32 },
    33 error:function(){
    34 // 传输失败
    35 console.log("请求失败!");
    36 }
    37 });
    38 });
    39 </script>
    40 </html>
    View Code
     使用ajax的get的方法:$.get:
     1 <!DOCTYPE html>
     2 <htmllang="en">
     3 <head>
     4 <metacharset="UTF-8"/>
     5 <title>Document</title>
     6 </head>
     7 <body>
     8 姓名:<inputtype="text"name="user">
     9 年龄:<inputtype="text"name="age">
    10 <inputtype="button"value="输入">
    11 <divstyle="border:1px solid red;padding:30px">
    12 <h2>你的信息:</h2>
    13 <p>XXX</p>
    14 <p>XXX</p>
    15 </div>
    16 </body>
    17 <scripttype="text/javascript"src="http://apps.bdimg.com/libs/jquery/2.1.4/jquery.min.js"></script>
    18 <scripttype="text/javascript">
    19 var $btn = $("input[type=button]");
    20 var $input = $("input[type=text]");
    21 var $p = $("p");
    22 $btn.on("click",function(){
    23 // 使用jq的ajax的get方法
    24 // $.get("1-jq-ajax-get.php");
    25 $.get("1-jq-ajax-get.php",{ name:$input.eq(0).val(), age:$input.eq(1).val()},function(data){
    26 console.log(data);
    27 $p.eq(0).text(data.name);
    28 $p.eq(1).text(data.age);
    29 },"json");
    30 });
    31 </script>
    32 </html>
    View Code
     
    使用ajax的post的方法:$.post:
    $.post(url,[data],[callback],[type]);
    $.post("test.php", { name: "John", time: "2pm" },
    function(data){
    process(data);
    }, "xml");
  • 相关阅读:
    经典算法之冒泡排序(Bubble Sort)-Python实现
    经典算法之快速排序(Quick Sort)-Python实现
    2020年SRE的随心感悟
    django: 像正常运行django的项目运行单个文件
    整理一下javascript中offsetWidth、clientWidth、width、scrollWidth、clientX、screenX、offsetX、pageX的具体含义
    requestAnimationFram 的优势及使用场景
    js 隐式数据转换带来的BUG
    为什么我不建议在js中使用链接变量分配
    关于JS函数传参的数据修改
    实现一个查看浏览器内核及版本号的功能函数
  • 原文地址:https://www.cnblogs.com/ChenChunChang/p/6616107.html
Copyright © 2011-2022 走看看