u010384336 2017-03-27 07:31 采纳率: 90.9%
浏览 1335
已采纳

JQuery回调函数内变量赋值问题

 <html>
<head>
<script src="http://apps.bdimg.com/libs/jquery/2.1.4/jquery.min.js"></script>
<script>
getImgWH("http://lailailailai.yungler.com/196/media/img/9efa87c0f465288e.jpg");

function getImgWH(path) {

        var realwidth;
        $("<img/>").attr("src", path).load(function() {

            realwidth = this.width;
            alert(realwidth); //160
        });
        alert(realwidth); //undefined
}
</script>
<head>

<body></body>
</html>

代码如上,在回调函数内,可以正常给realwidth赋值,但是出了回调函数之后realwidth的值就变成了undefined,求解要怎么才能获取到realwidth。

  • 写回答

2条回答 默认 最新

  • Go 旅城通票 2017-03-27 07:34
    关注

    图片加载是异步的,就是执行 alert(realwidth); //undefined这句的时候load都没有执行,当然是默认的undefined,要改为回调的形式调用

    和异步ajax一个意思,也要居于回调才能获取ajax异步返回值,不过ajax支持同步请求,img对象不行

    
        getImgWH("http://lailailailai.yungler.com/196/media/img/9efa87c0f465288e.jpg", function (realwidth) { alert(realwidth); });
    
        function getImgWH(path,callback) {
    
            var realwidth;
            $("<img/>").attr("src", path).load(function () {
    
                realwidth = this.width;
                callback(realwidth); //160
            });
        }
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

悬赏问题

  • ¥15 gradio的web端页面格式不对的问题
  • ¥15 求大家看看Nonce如何配置
  • ¥15 Matlab怎么求解含参的二重积分?
  • ¥15 苹果手机突然连不上wifi了?
  • ¥15 cgictest.cgi文件无法访问
  • ¥20 删除和修改功能无法调用
  • ¥15 kafka topic 所有分副本数修改
  • ¥15 小程序中fit格式等运动数据文件怎样实现可视化?(包含心率信息))
  • ¥15 如何利用mmdetection3d中的get_flops.py文件计算fcos3d方法的flops?
  • ¥40 串口调试助手打开串口后,keil5的代码就停止了