14

我有一个链接按钮,用于从页面内容构建邮件。在不打开空白窗口或干扰调用它的窗口的情况下从 javascript 启动它的最佳方法是什么?

function Email()
{
    var sMailTo = "mailto:";
    var sBody = "";

    var alSelectedCheckboxes = new Array();
    $("input:checkbox[CheckBoxType=Email]:checked").each(function()
    {
        alSelectedCheckboxes.push($(this).val());
    });

    if (alSelectedCheckboxes.length > 0)
    {
        for (var i=0; i<alSelectedCheckboxes.length; i++)
        {
            sBody += alSelectedCheckboxes[i];
            sBody += "\n";
        }

        sMailTo += escape("<Insert Recipients Here>") +"?subject=" +escape("<Insert Subject Here>") +"&body=" +escape(sBody);
        window.location.href = sMailTo;
    }
    else
    {
        alert("Please select some results");
    }
}

简单的功能如上。window.location.href 不能正常工作,除非它是 Firefox/Chrome(它在 IE8 中重绘页面)。我也尝试过 window.open(sMailTo, "_self") 但在 IE8 中这再次破坏了调用它的页面。

我敢肯定这是一个愚蠢的问题.... :-)

谢谢

4

2 回答 2

10

我觉得一点都不傻!这是一个好的开始。我接下来要尝试的是在 jquery 中创建一个实际的链接对象,将其附加到正文,然后单击()它。

//window.location.href = sMailTo;
$('<a href="' + sMailTo + '">click</a>').appendTo('body').click().remove();

只要您使用的 escape() 函数去掉所有引号并正确编码 html,就应该可以工作。

但我不得不说,这可能很难做到恰到好处。如果它仍然不起作用,我建议在服务器端进行,链接发布所有需要的 html。

于 2011-03-10T20:09:37.707 回答
3

如果您使用的是 jQuery,那么您可以轻松地根据您构建的标记创建一个元素(请参阅此答案以获取示例),然后只需执行以下操作即可调用链接的单击事件:

element.click();
于 2011-03-10T20:08:42.907 回答