js如何异步执行方法

a和b方法,functionc(){a();b();}执行a的同时,也可以执行b,不用等a执行完再执行b,具体要怎么写嗯,是多线程... a和b方法,
function c(){
a();

b();

}
执行a的同时,也可以执行b,不用等a执行完再执行b,具体要怎么写
嗯,是多线程
展开
 我来答
百度网友0df1ab6
推荐于2018-03-28 · TA获得超过147个赞
知道小有建树答主
回答量:194
采纳率:0%
帮助的人:107万
展开全部
var xmlHttp;
function createXMLHttpRequest(){
//Mozilla 浏览器(将XMLHttpRequest对象作为本地浏览器对象来创建)
if(window.XMLHttpRequest){ //Mozilla 浏览器
xmlHttp = new XMLHttpRequest();
}else if(window.ActiveXObject) { //IE浏览器
//IE浏览器(将XMLHttpRequest对象作为ActiveX对象来创建)
try{
xmlHttp = new ActiveXObject("Msxml2.XMLHTTP");
}catch(e){
try {
xmlHttp = new ActiveXObject("Microsoft.XMLHTTP");
}catch(e){}
}
}
if(xmlHttp == null){
alert("不能创建XMLHttpRequest对象");
return false;
}
}
//用于发出异步请求的方法
function sendAsynchronRequest(url,parameter,callback){
createXMLHttpRequest();
if(parameter == null){
//设置一个事件处理器,当XMLHttp状态发生变化,就会出发该事件处理器,由他调用
//callback指定的javascript函数
xmlHttp.onreadystatechange = callback;
//设置对拂去其调用的参数(提交的方式,请求的的url,请求的类型(异步请求))
xmlHttp.open("GET",url,true);//true表示发出一个异步的请求。
xmlHttp.send(null);
}else{
xmlHttp.onreadystatechange = callback;
xmlHttp.open("POST",url,true);
xmlHttp.setRequestHeader("Content-Type","application/x-www-form-urlencoded;");
xmlHttp.send(parameter);
}
}
//以上代码是通用的方法,接下来是调用以上的方法
function loadPros(title,count,pid,cid,level){
// 调用异步请求方法
url = "。。。。。。。。";
sendAsynchronRequest(url,null,loadCallBack);
}
// 指定回调方法
function loadCallBack(){
try
{
if (xmlHttp.readyState == 4) {
if (xmlHttp.status == 200) {
if(xmlHttp.responseText != null && xmlHttp.responseText != ""){
var divProid = document.getElementById('videolist');
divProid.innerHTML = xmlHttp.responseText;
for(i=0;i<len;i++)
{
var video_url = document.getElementById("videolist"+i+"").href;
if(video_url != undefined && video_url != null && video_url != ""){
window.location.href = video_url;
}
}
}
}
}
if (xmlHttp.readyState == 1)
{
//alert("正在加载连接对象......");
}
if (xmlHttp.readyState == 2)
{
//alert("连接对象加载完毕。");
}
if (xmlHttp.readyState == 3)
{
//alert("数据获取中......");
}
}
catch (e)
{
//alert(e);
}
}
匿名用户
推荐于2016-11-03
展开全部
function myThread(callback){

  return setTimeout(1000*10,function(){

    $("#div").append("<p>hello</p>");//10秒后在div中加一个行,然后在执行callback函数

    callback();

  });

}

 用回调函数

function A(fun){    

 var temp = 100;   

 temp = temp * temp;    

 window.setTimeout(function(){  

       fun(temp);

    },0);

 alert("a函数:"+temp);

}

function B(r){    

 alert("b函数"+r);

}

A(B);// 调用
本回答被提问者采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
神鹰坤
2015-11-23 · TA获得超过194个赞
知道答主
回答量:78
采纳率:0%
帮助的人:11.5万
展开全部
ajax:
$.ajax({
type: "post",
url:"http://i.ui.cn/jsonpSendlt",
dataType:'jsonp',
data:lettersData,
success:function(result) {
if(result.code == 1){
globalTip(result);

$this.removeClass('loading');
$this.text('确定');

//关闭弹窗,恢复样式
$('#modal-letter').removeClass("in");
$('.modal-backdrop').remove();
$('body').removeClass("modal-open");
$('body').css('padding-right','0');

//输入框清空
$('textarea[name=lettersval]').val('');
}else{
globalTip(result);

$this.removeClass('loading');
$this.text('确定');

$('textarea[name=lettersval]').focus();
return false;
}
},
timeout:3000
});
return false;
});
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
百度网友177257b46
2013-08-16 · TA获得超过803个赞
知道小有建树答主
回答量:427
采纳率:100%
帮助的人:341万
展开全部
第一,要分清楚什么是异步,什么事多任务,什么是多线程。
第二,这不是异步,这是多任务,抱歉,浏览器不支持哦。
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
普利斯丶
2015-08-18 · TA获得超过873个赞
知道小有建树答主
回答量:170
采纳率:100%
帮助的人:120万
展开全部
异步可以用ajax技术,最好用jQuery+ajax进行使用,可以设置async : false 关闭异步。
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(4)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式