V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
Reign
V2EX  ›  程序员

js 中怎样让语句在 img onload 之后按顺序执行?

  •  
  •   Reign · 2018-05-18 18:39:07 +08:00 · 3157 次点击
    这是一个创建于 2384 天前的主题,其中的信息可能已经有所发展或是发生改变。
    var size=[];
    var img=new Image();
    img.src="https://i0.pickpik.com/photos/333/210/523/chipmunk-garden-spring-flowers-thumb.jpg";
    img.onload=function()
    {
    	size=[img.naturalWidth,img.naturalHeight];
    }
    var sum=size[0]+size[1];
    console.log(sum);
    //继续执行下面大量语句
    

    上述代码中,要等 img onload 执行完之后再按顺序执行以下语句,我不希望把下面的语句都放在 img onload 里面,求 V 友该怎么做?

    7anshuai
        1
    7anshuai  
       2018-05-18 19:50:34 +08:00
    img onload 里加个 callback 调用,或者试试 async.js
    KuroNekoFan
        2
    KuroNekoFan  
       2018-05-18 20:19:19 +08:00 via iPhone
    除了 async/await 应该没有别的办法了,如果一层嵌套都受不了的话
    lamada
        3
    lamada  
       2018-05-18 21:03:59 +08:00 via Android
    await loadImage()
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   5647 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 31ms · UTC 06:41 · PVG 14:41 · LAX 22:41 · JFK 01:41
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.