一個通用的Confirmation Page類

來源:互聯網
上載者:User
Confirmation Page


1. Introduction

In New or Edit page, users might press the Close button by mistake and lost the content that they have input. To avoid this mistaken action, application should prompt users before the page is closed. This page will not be closed unless users confirm that.



This document gives the implementation details for how the Confirmation Page works. It can be used in:

? New Page

? Edit Page

? Any other pages need confirmation before close



2. Solution

2.1 ConfirmationPage Class

ConfirmationPage class is available in the root of XXXWeb project. This is a class derived from PageBase.

This class implements the function of “cause the user to confirm navigating away from the current page”.



using System;
using System.IO;
using System.Text;
using System.Text.RegularExpressions;
using System.Web.UI;


namespace Proloq.ProloqWeb
{
/// <summary>
/// Will cause the user to confirm navigating away from the current page. This behavior can be overriden.
/// </summary>
public class ConfirmationPage : Proloq.ProloqWeb.PageBase
{
public ConfirmationPage()
{
}

private bool _IsInEdit = false;
public bool IsInEdit
{
get {return this._IsInEdit;}
set {this._IsInEdit = value;}
}

private string _message = "You will lose any non-saved text";
public string Message
{
get{return _message;}
set{_message = value;}
}

protected override void OnPreRender(EventArgs e)
{
//If we are in edit mode, register the script
if(IsInEdit)
{
Page.RegisterClientScriptBlock("ConfirmationBeforeLeaving",string.Format("{0}{1}{2}",scriptStart,Message,scriptEnd));
}
base.OnPreRender (e);
}



const string scriptStart = "<script language=\"javascript\">g_blnCheckUnload = true;function RunOnBeforeUnload() {if (g_blnCheckUnload) {window.event.returnValue = '";
const string scriptEnd = "'; } } function bypassCheck() { g_blnCheckUnload = false; }</script>";

public static readonly string ByPassFuncationName = "bypassCheck()";


protected override void Render(HtmlTextWriter writer)
{

//If we are in edit mode, wire up the onbeforeunload event
if(IsInEdit)
{
TextWriter tempWriter = new StringWriter();
base.Render(new HtmlTextWriter(tempWriter));
writer.Write(Regex.Replace(tempWriter.ToString(),"<body","<body onbeforeunload=\"RunOnBeforeUnload()\"",RegexOptions.IgnoreCase));
}
else
{
base.Render(writer);
}
}
}
}




2.2 Implement in Codeback

2.2.1 Inheritance

The pages going to use ConfirmationPage should derived from ConfirmationPage class. Take Product Edit page for example:

public class product_edit : ConfirmationPage





2.2.2 In CodeBehind

Put a private function like bellow in CodeBehind:

private void SetConfirmation()

{

ConfirmationPage confirmPage = (ConfirmationPage)this.Page;

confirmPage.IsInEdit = true;

confirmPage.Message = "You will lose any unsaved content";



this.SaveButton.Attributes.Add("OnClick",ConfirmationPage.ByPassFuncationName);

}























SaveButton is the button which you do not want to issue the confirmation. Add other buttons you want here.



And in PageLoad, you should use this SetConfirmation() function:

private void Page_Load(object sender, System.EventArgs e)

{



SetConfirmation();



}













2.2.3 In .aspx file

If there are some buttons are not run at server, you should put following code for them. Take Cancel button in Product Edit page for example:

<IMG style="CURSOR: hand" onclick="javascript:bypassCheck();GoBack();" src=http://www.163design.net/n/f/"<%=Image1URLBase%>/btn_cancel_g.gif" border="0">









bypassCheck() function is to clear the confirmation for the page.




相關文章

E-Commerce Solutions

Leverage the same tools powering the Alibaba Ecosystem

Learn more >

Apsara Conference 2019

The Rise of Data Intelligence, September 25th - 27th, Hangzhou, China

Learn more >

Alibaba Cloud Free Trial

Learn and experience the power of Alibaba Cloud with a free trial worth $300-1200 USD

Learn more >

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。