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>
若有不足请多多指教!希望给您带来帮助!
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对自由互联的支持。如果你想了解更多相关内容请查看下面相关链接