jquery工具Overlay:打开基于ajax响应的覆盖

发布于 12-03 03:17 字数 817 浏览 2 评论 0原文

我正在尝试通过单击按钮打开叠加层。该按钮与一个 ajax 调用关联,如果返回错误,则应打开一个覆盖层,但成功后,该覆盖层不会打开。

发生的情况是,无论 ajax 响应是否成功/错误,覆盖层都会打开。它在单击按钮时打开,而不是在 ajax 响应时打开。我在这里缺少什么???

这就是我正在尝试的...

//Overlay setup
$('#PostQuestion').overlay({
    target: "#template"
});

//Ajax call setup
$('#PostQuestion').click(function() {
    $.ajax({
        url: '/ask_away',
        dataType: "json",
        data: {question: 'something'},
        type: 'POST',
        cache: false,
        success: function(response) {
            alert("It was a success");
        },
        error: function(request, error) {
            $('#PostQuestion').data('overlay').load();
        }
    });
});

<!-- HTML Here -->
<div id="template">You got an error</div>
<div id="PostQuestion">Ask Question</div>

I am trying to open an overlay on a button click. The button has associated with it an ajax call, which if returns an error should open an overlay, but on success the overlay does not open.

What happens is that the overlay opens regardless of success/error in ajax response. It opens on button click, not on ajax response. What am I missing here???

Here is what I am trying...

//Overlay setup
$('#PostQuestion').overlay({
    target: "#template"
});

//Ajax call setup
$('#PostQuestion').click(function() {
    $.ajax({
        url: '/ask_away',
        dataType: "json",
        data: {question: 'something'},
        type: 'POST',
        cache: false,
        success: function(response) {
            alert("It was a success");
        },
        error: function(request, error) {
            $('#PostQuestion').data('overlay').load();
        }
    });
});

<!-- HTML Here -->
<div id="template">You got an error</div>
<div id="PostQuestion">Ask Question</div>

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

浮萍、无处依2024-12-10 03:17:48

无论 ajax 调用是否成功/错误,覆盖层都会显示的原因是:

$('#PostQuestion').overlay({
    target: "#template"
});

基本上定义了 #PostQuestion div 的单击处理程序以打开覆盖层。因此,一旦您单击 PostQuestion div,您不仅会发送 ajax,还会显示叠加层(正如我所说的上面代码片段的结果)。

要使其按预期工作,请检查下面的代码。还有一个简短的旁注 - 即使 ajax 调用返回 200 OK,但不是正确的 json 数据,错误处理程序也会被使用,所以在开发时请记住这一点。

$(function() {
            //Overlay setup
            //select the overlay element in the jQuery selector and not the trigger element
            $("#template").overlay();

            //Ajax call setup
            $('#PostQuestion').click(function() {
                $.ajax({
                    url: '/ask_away',
                    dataType: "json",
                    data: {question: 'something'},
                    type: 'POST',
                    cache: false,
                    success: function(response) {
                        alert("It was a success");
                    },
                    error: function(request, error) {
                        $("#template").data('overlay').load();
                    }
                });
            });
        })

The reason the overlay is showing regardles of success/error of ajax call is because this:

$('#PostQuestion').overlay({
    target: "#template"
});

basically defines click handler for #PostQuestion div to open an overlay. So once you click PostQuestion div you not only sending the ajax but also showing the overlay (which is as I said result of the code snippet above).

To make it work as desired check the code below. Just one more quick side-note - even if the ajax call return 200 OK, but not a proper json data the error handler will be used, so keep that in mind while developing.

$(function() {
            //Overlay setup
            //select the overlay element in the jQuery selector and not the trigger element
            $("#template").overlay();

            //Ajax call setup
            $('#PostQuestion').click(function() {
                $.ajax({
                    url: '/ask_away',
                    dataType: "json",
                    data: {question: 'something'},
                    type: 'POST',
                    cache: false,
                    success: function(response) {
                        alert("It was a success");
                    },
                    error: function(request, error) {
                        $("#template").data('overlay').load();
                    }
                });
            });
        })
~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文