如何实现返回确认像对话但使用jgrowl?

时间:2011-08-13 01:54:31

标签: javascript jquery dialog confirmation jgrowl

我正在使用论坛脚本(简单机器论坛) 它正在使用这种javascript确认消息:

<a href="http://domain.net/index.php?action=deletemsg;topic=1.0;msg=1;c6c7a67=f9e1fd867513be56e5aaaf710d5f29f7" onclick="return confirm('Remove this message?');">Remove</a>

我想用jgrowl来代替那样......

<a href="http://domain.net/index.php?action=deletemsg;topic=1.0;msg=1;c6c7a67=f9e1fd867513be56e5aaaf710d5f29f7" onclick="$.jGrowl('Remove this message?', { header: 'Confirmation', sticky: true });"/>Remove</a>

但是......如何使用jgrowl实现真/假javascript返回? 可以在一行中完成吗?

祝你好运! 卢西亚诺

1 个答案:

答案 0 :(得分:0)

编辑以支持使用href

你不能这样做,因为jGrowl不会是模态的并阻止你的页面行为。

但是,您可以在选择完成后为要执行的代码创建一个函数,然后从通知中调用它

请查看此示例http://jsfiddle.net/rcxVG/11/

html

<body>
    <a href="javascript: startDemo(1); alert('a');">link for 1</a><br>
    <a href="javascript: startDemo(2); ">link for 2</a><br>
        Will we notify again<div id="will-notitfy-again">yes</div>

    <br>
    now... If you want to return then
    <a href="http://www.google.com" data-confirmed="false" onclick="return returnModal(this);">click me</a>
</body>

JS

function startDemo(id)
{
    $.jGrowl("to do not notify again click <a href='javascript:notFor("+id+")' onclick='closeNotif(this);'>here</a>!", { sticky: true });
}

function notFor(id){
    alert("not anymore for "+id);
    $("#will-notitfy-again").html("remember, notFor was hit for"+id);

}

function closeNotif(panel){
    $(".jGrowl-notification").has(panel).find(".jGrowl-close").click();
}
var counter=0;
var confirmedAttr="data-confirmed";
function returnModal(field){
    var $field=$(field);
    if($field.attr(confirmedAttr)=="true"){
        location.href=$field.attr("href");
    }else{
        counter++;
        //save the element somewhere so we can use it (don't know if it has an unique-id)
        $(document).data("id"+counter,$field);
        $.jGrowl("click <a href='javascript:confirmClick("+counter+")' onclick='closeNotif(this);'>here</a> to go to google!", { sticky: true });
        return false;
    }
}
function confirmClick(variableId){
    var $field=$(document).data("id"+variableId);
    $field.attr(confirmedAttr,"true");
    $field.click();
}

如果这是好事,请告诉我

相关问题