为什么我不能从$(document).ready调用外部函数

时间:2013-01-04 17:46:07

标签: javascript jquery document

使用下面的代码,点击按钮不会调用handleData()函数, 如果我使用匿名函数方式(在/ * * /中),它可以工作。

有人可以解释问题是什么吗?以及如何解决它? 我想从$(document).ready(...)调用全局函数。

<html>
<head>
<script src="js/jquery/jquery-1.7.2.min.js"></script>

<script>
    function handleData(data, status) {
        $("#p1").text(data);
    };

    $(document).ready(function() {

        $("button").click(function() {
            $.get("testAsync?name=value", handleData(data, status));
        });

        /*
        $("button").click(function() {
            $.get("testAsync?name=value", function(data, status) {
                $("#p1").text(data);
            });
        });
         */
    });
</script>
</head>
<body>
    <button>Send an HTTP GET</button>
    <p id="p1"></p>
</body>
</html>

2 个答案:

答案 0 :(得分:5)

正在立即调用该函数,因为之后有(arguments)

由于参数是有序的,所以只需单独传递handleData

答案 1 :(得分:5)

更改功能调用
$.get("testAsync?name=value", handleData(data, status));

$.get("testAsync?name=value", handleData);

在第一种情况下,您正在立即执行该函数..只需传入函数指针,它将按预期工作..