欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

详解jQuery中关于Ajax的几个常用的函数

程序员文章站 2023-02-24 10:19:05
一: ajax 是一种在无需重新加载整个网页的情况下,能够更新部分网页的技术。 什么是 ajax ? ajax = 异步 javascript 和 xml。 aja...

一:

ajax 是一种在无需重新加载整个网页的情况下,能够更新部分网页的技术。

什么是 ajax ?

ajax = 异步 javascript 和 xml。

ajax 是一种用于创建快速动态网页的技术。

通过在后台与服务器进行少量数据交换,ajax 可以使网页实现异步更新。这意味着可以在不重新加载整个网页的情况下,对网页的某部分进行更新。

传统的网页(不使用 ajax)如果需要更新内容,必需重载整个网页面。

有很多使用 ajax 的应用程序案例:新浪微博、google 地图、开心网等等。

二:传统的ajax过于繁琐,jquer封装了一些ajax常用的简单函数。

   a:  $.ajax()方法:

   jsp页面代码 :

<head>
  <title>ajax验证</title>
  <script type="text/javascript" src="js/jquery-1.8.3.min.js"></script>
  <script type="text/javascript">
    $(function () {
      $("[name='username']").blur(function () {     
        $.ajax({
          type: "post",
          url: "/testservlet",
          data:{action:"login"},     //data 传递的参数一般都是key:“ value” 类型的 value一定要加引号 我亲身体验 那种找不到错的感觉
          // datatype:'text',      //servers 返回的格式 也可以是gjon
          success: function (data) {
            if (data == "success") {
              alert(data);
              $("#myspan").html(data);
            }
          },
          error: function () {      //这个用的比较少
          }
        })
      })
    })
  </script>
</head>
<body>
   姓名: <input name="username" type="text"><span id="myspan"></span>
   密码: <input name="password" type="text">
</body>

     servlet后台代码:

public class testservlet extends httpservlet {
  protected void dopost(httpservletrequest request, httpservletresponse response) throws servletexception, ioexception {
    string name = request.getparameter("action");
    system.out.println(name);
    if(name.equals("login")){
      response.getwriter().write("success");  //返回回掉函数的参数
    }else{
      response.getwriter().write("file");
    }
  }

   b:$.get() , $.post()和 $.getjson方法都是$.ajax()方法的精简版,用法大致一致,少了一个type

$.post("/testservlet",
         {"uname":$('[name=uname]').val()},
         function (data) {
           alert(data);
         });

   c: $.load()

$("#msg").load(     //可以直接拿到文本框 的值
         "/testservlet","action="+$('[name="username"]').val()
         );
//后台可以直接 根据request.getparameter()拿到参数的值 

   d:$(selector).serializearray() 和$(selector).serialize()  

 //这种方法 可以直接 获得form表单的name属性值,作为data的传参
 var data1 = $("#form1").serializearray(); //自动将form表单封装成json
           $.each(data1,function (i,dom) {
             alert(dom.name+"\r\n"+dom.value);
           });
           var data2=$("#form1").serialize();
           alert(data2);

   e:作为data参数

 var data2=$("#form1").serialize();
           $.getjson("/testservlet",data2, function (data) {
              alert(data);
           });

以上所述是小编给大家介绍的jquery中关于ajax的几个常用的函数,希望对大家有所帮助