1.同步请求 发送了同步请求后 会一直等待 先执行 alert("result:" + d); temp = d; 在执行alert("this is last:"+temp); 不能操作页面上的其他内容,会造成当前UI线程阻塞
<!DOCTYPE html>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8"/>
<title></title>
<meta charset="utf-8" />
<script type="text/javascript" src="Scripts/jquery-1.10.2.min.js"> </script>
<script type="text/javascript">
$(function () {
$.ajaxSetup({
async: false
}); var temp = 0;
$("#a1").click(function () {
$.post("home/test", { async: false }, function (d) { alert("result:" + d); temp = d; }); alert("this is last:"+temp); }) }) </script>
</head>
<body>
<a id="a1"> this is a1</a>
<p>dddddddddddddddddddddddddddddddddddddddddd</p>
<input type="button" value="btn" />
</body>
</html>
2.异步请求,发送完异步请求后 先执行 alert("this is last:"+temp);再执行 alert("result:" + d); temp = d; 能够操作浏览器的其他内容,不会造成当前UI线程阻塞
<!DOCTYPE html>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title></title>
<meta charset="utf-8" />
<script type="text/javascript" src="Scripts/jquery-1.10.2.min.js"> </script>
<script type="text/javascript">
$(function () {
$.ajaxSetup({
async: true
}); var temp = 0;
$("#a1").click(function () {
$.post("home/test", function (d) { alert("result:" + d); temp = d; }); alert("this is last:"+temp); }) }) </script>
</head>
<body>
<a id="a1"> this is a1</a>
<p>dddddddddddddddddddddddddddddddddddddddddd</p>
<input type="button" value="btn" />
</body>
</html>
异步/同步 是得到消息的方式。 同步方式一直等待结果,而异步方式是回调(或其他方式通知)通知结果
阻塞/非阻塞是否当前UI线程能做其他事情 。当前线程一直等待不能做其他事情就造成阻塞,当前线程做其他事情 就不会造成阻塞