当前位置:Gxlcms > JavaScript > Jquery的Ajax技术使用方法

Jquery的Ajax技术使用方法

时间:2021-07-01 10:21:17 帮助过:3人阅读

Jquery的Ajax技术(重点)

jquery是一个优秀的js框架,自然对js原生的ajax进行了封装,封装后的ajax的操作方法更简洁,功能更强大,与ajax操作相关的jquery方法有如下几种,但开发中经常使用的有三种:

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

2)$.post(url, [data], [callback], [type])

区别:get有字节码乱码问题,post无字节码乱码问题(获取请求页面数据到后台,后台response.setContextType(“text/html;charset=UTF-8”)响应乱码问题还与原来一样)

其中:

  •     url:代表请求的服务器端地址
  •     data:代表请求服务器端的数据(可以是key=value形式也可以是json格式)
  •     callback:表示服务器端成功响应所触发的函数(只有正常成功返回才执行)
  •     type:表示服务器端返回的数据类型(jquery会根据指定的类型自动类型转换)常用的返回类型:text、json、html等

如果type为json,并且服务器端返回的就是json格式字符串jq内部会帮我们自动转化,在回调函数中获取的实参就是转化完成的js对象直接使用即可。

参数的顺序可更换的,但是如果把data放在后面会出现无法传递数据的问题,所以不要擅自更换严格按照jq文档中的顺序进行使用。

function get(){
   $.get(
     "/web22-ajax/ajaxServlet2",//url
     {"name":"muzidigbig","age":22},//请求参数,json的数据格式
     function(data){//请求成功后返回过来的参数
       alert(data.name+data.age);
     },
     "json"
   );
  };
//java只能是java代码,前端页面的代码只能转换成json对象
response.getWriter().write("{\"name\":\"muzi\",\"age\":22}");

3)$.ajax( { option1:value1,option2:value2... } ); (重要)

常用的option有如下:

    async:是否异步,默认是true代表异步

    url:请求服务器端地址

    type:请求方式,POST/GET(不写默认get)

    data:发送到服务器的参数,建议使用json格式

    success:成功响应执行的函数,对应的类型是function类型,请求成功后获得的值会自动封装在这个函数的第一个参数中

    error:失败响应执行的函数,对应的类型是function类型

    dataType:服务器端返回的数据类型,常用text和json

beforeSend:function (argument) {},// 在发送请求之前调用,可以做一些验证之类的处理如果返回false可以取消本次ajax请求。

<body>
<button>发送请求</button>
</body>
<script src="jquery-3.3.1.js"></script>
<script>
  $('button').click(function () {
    $.ajax({
      async:true,
      url:"向后台地址发送请求",
      type:'post',//请求的方式
      data:{'name':'muzidigbig','age':'20'},//请求的数据
      success:function (backdata) {//请求成功后返回的数据会封装在回调函数的第一个参数中
        //通过backdata来获取所需要的数据
        alert(backdata.name+backdata.age);
      },
      error:function () {//响应不成功时返回的函数
        console.log('请求失败!')
      },
      dataType:'json'//设置返回的数据类型
    })
  });
</script>

若有不足请多多指教!希望给您带来帮助!

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对脚本之家的支持。如果你想了解更多相关内容请查看下面相关链接

人气教程排行