怎么让js函数 一个执行完之后在执行另外一个?

functionstart_flow(){start_project();start_config();...}functionstart_project(){...}f... function start_flow()
{
start_project();
start_config();
...
}

function start_project()
{
...
}

function start_config()
{
...
} 函数中有ajax异步请求 所以 没有办法使得前一个函数执行完后 后一个在执行
现在的问题是start_project()还没有执行完成就开始执行start_config()了,这样会出错,
想达到的效果是start_project()执行完成再start_config(),请问要如何做? 有两个可行的方法 一 为 settimeout 创立时间差(肯定可行) 二为 确定一个返回值 true 判断返回值 是否执行成功(这个没有试验过 感觉可能不太可行) 我想请问的是 有没有效率高一点的 更好的方法?
展开
 我来答
百度网友2d649ec
2018-04-04 · TA获得超过7132个赞
知道小有建树答主
回答量:85
采纳率:100%
帮助的人:5.5万
展开全部

第一种情况:运动函数执行完之后再执行另外一个函数 
注释:按钮点击之后,div先显示出来,然后宽度和高度再增加到300px

<button class="btn">点击我</button><div id="div2">
<p>人的灵魂所必须的东西,是不需要用金钱来买的</p></div><style>
div{height: 200px;width: 200px;padding:15px;background: #ececec;display: none;}</style><script>$().ready(function(){
$('.btn').click(function(){
$('div').show();
$('div').animate({            'width':'300px',            'height':'300px'
},1000)
})
})12345678910111213141516171819
或者这样写,如果div的高度宽度增加到300px,然后会执行另外一个函数,div的背景色会变成绿色
$().ready(function(){
$('.btn').click(function(){
$('div').show();
$('div').animate({            'width':'300px',            'height':'300px'
},function(){
$(this).css('background','green')
})
})
})123456789101112

第二种情况:把函数a绑定到函数c 上,按钮点击的时候执行函数c,传入的参数是a ,那么函数就先执行函数a(),然后再执行函数b();就形成了先后执行函数

$().ready(function(){
$('.btn').click(function(){
c(a);
})
})function a() {
$('div').animate({'width':'300px'},1000)
}function b(){
$('div').animate({'height':'300px'},1000)
}function c(x){
x();
b();
}

不二进制
2014-02-17 · TA获得超过749个赞
知道小有建树答主
回答量:441
采纳率:50%
帮助的人:322万
展开全部

1、直接在 start_project 函数中执行start_config 

function start_flow()
{
    start_project();
    //start_config();
    ...
}
 
function start_project()
{
    ...
    start_config();// 在这里执行
}
 
function start_config()

    ...
}

2、或者做成callback函数

function start_flow()
{
    start_project( start_config );
    //start_config();
    ...
}
 
function start_project( callback )
{
    ...
    if(typeof callback != "undefined")
        callback();// 执行调用函数
}
 
function start_config()

    ...
}
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
狂雪嬴昭
2019-04-16 · TA获得超过3.7万个赞
知道大有可为答主
回答量:1.4万
采纳率:27%
帮助的人:712万
展开全部
你可以把另外执行的那个函数封装起来呀,在第一个函数的最后再调用,这样就达到你的要求的了。
比如这样:
function
onclick()//这是一个点击事件{
alert("这是一个点击事件");
onclick2();//这里是调用第二个函数的地方}function
onclick2()
//...
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
wuxd7
2014-02-17 · TA获得超过323个赞
知道小有建树答主
回答量:452
采纳率:100%
帮助的人:286万
展开全部
start_project 添加一个参数,
start_project(fn){
………………
fn()

}
function start_flow()
{
start_project(start_config);
……
}
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
qq1111qq111111
2014-02-17 · TA获得超过1175个赞
知道小有建树答主
回答量:1166
采纳率:66%
帮助的人:614万
展开全部
把start_config()放到start_project()方法中调用
追问
谢谢您的回复  这种方法没有用
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(5)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

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

类别

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

说明

0/200

提交
取消

辅 助

模 式