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 milvus查询出来的score怎么转换成0-1之间的相似性
  • ¥15 多ip服务器站群如何搭建l2tp服务器
  • ¥15 lvgl V9移植到linux开发板
  • ¥15 VB.net中在窗体中创建一个button控件来关闭窗体,但是提示错误,我该怎么办
  • ¥15 网上下载好的程序但是arduinoIDE编程报错,运行不了,哪里出错了,能具体给改一下吗
  • ¥15 Sharepoint JS开发 付费技术指导
  • ¥15 输入程序运行仿真后,烟雾值不实时检测,变成固定值
  • ¥20 数据排序,可选择排序方向
  • ¥15 修改一下代码,考虑进程到达时间不同的情况
  • ¥15 帮我看看这是个啥题,带解题过程和结果,条件如下FCF = 290471.33 g1 = 15% r = 8% g2 = 4% n = 5