1

以下は、ボタンを新しいページに開くための私のコードですが、クリック時の機能はより複雑です。ここで後処理も行われ、window.open in as popup ブロックが作成されます。

投稿機能を削除して試してみましたが、新しいページは完全に機能します。誰でもこの問題で助けてくれますか。

$('#catalog_demo_button a').click(function(e) {         
        var curEmailId = $('#field-email').val();           
        var validemail = validateEmail(curEmailId);
        if (validemail) 
        {   
        RSUI.util.setCookie("curEmailIdsc", curEmailId);
        $.post($("#targetform").val(), 
        {
            email : $('#field-email').val(),
            demo_lang : $('#selectedLang').val(),
            cis_name : $("#cis_name").val(),
            website : $("#website").val(),
            form_type : "demo",
            demo_type : $("#form_type").val(),
            form_url : $("#form_url").val(),
            cid : $.trim(RSUI.util.getCookie('affiliate'))
        },function(data) 
        {
            if (data != "")
            {
                data = eval("("+data+")");
                if (data[0].cisFlag == "true")                                  
                {                           
                    s.events="event19";
                    s.t();
                    delete s.events;
                    s.sendFormEvent('s', s.pageName, "Demo Email Form");
                    adconionConversionCall();   



                    var demolangid = $("[name=language_code]").val();
                    URL= 'url'+demolangid; 
                        if(demolangid == 'ENG' || demolangid == 'ESC' || demolangid == 'ESP' || demolangid == 'DEU' || demolangid == 'FRA' || demolangid == 'ITA' || demolangid == 'SVE')   
                            $('#demo').overlay().load();
                        else
                            window.open(URL,'_blank')
                            $("#demoform a.close").click();
                    }
                else {
                    s.sendFormEvent('e', s.pageName, "Demo Email Form", "Email Submission Failed");
                }
            }   
        }, "");
    }
        else 
        {
            $("#field-email").val(errorEmailText);
            $('#field-email').css('border', '1px solid red');
            s.sendFormEvent('e', s.pageName, "Demo Email Form", "field-email");
        }
    });
4

1 に答える 1

1

ユーザーアクションによって呼び出されない場合、ポップアップはブロックされます。window.openは、ユーザーアクションではなく、POST成功コールバックにあります。

投稿を同期して、POSTの成功の外部からwindow.openを実行するか(テストされていませんが、論理的に聞こえます)、最初にポップアップを開いて後で入力する必要があります。

于 2012-10-15T13:29:39.243 に答える