Asp.Net C# でカスタム チェックボックス (通常のチェックボックスですが、もう 1 つのプロパティ: boolean LastValue) を作成したいので、ポストバック後に値が変更されたかどうかを知ることができます。あなたが提案する最良のアプローチは何ですか?
ありがとうございました!
Asp.Net C# でカスタム チェックボックス (通常のチェックボックスですが、もう 1 つのプロパティ: boolean LastValue) を作成したいので、ポストバック後に値が変更されたかどうかを知ることができます。あなたが提案する最良のアプローチは何ですか?
ありがとうございました!
から派生した新しいクラスを作成しCheckBox
てパブリック プロパティを追加し、LastValue
必ず LastValue を ViewState に保存します。
デフォルトの .ascx ファイルから、クラス名と LastValue プロパティを変更
using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.UI;
using System.Web.UI.WebControls;
namespace WebApplication1
{
public partial class MyCheckBox : CheckBox
{
protected void Page_Load(object sender, EventArgs e)
{
}
public string LastValue
{
get {
object s = ViewState["LastValue"];
return ( (s == null) ? "" : (string) ViewState["LastValue"] ) ;
}
set { ViewState["LastValue"] = value; }
}
}
}
デフォルトの .ascx マークアップの上部にある @Page:
<%@ Control Language="C#" AutoEventWireup="true" CodeBehind="WebUserControl1.ascx.cs" Inherits="WebApplication1.MyCheckBox" %>
ユーザー コントロールを含むマークアップを含む既定の aspx ページ。webApp をビルドした後、コントロールは自動的に汎用ツールボックスに配置されます。私のシステムでは、ツールボックスは「WebApplication1 コンポーネント」と呼ばれます。コントロールを既定のページにドロップすると、次のように作成されました。
<%@ Page Language="C#" AutoEventWireup="true" CodeBehind="WebForm1.aspx.cs" Inherits="WebApplication1.WebForm1" %>
<%@ Register assembly="WebApplication1" namespace="WebApplication1" tagprefix="cc1" %>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head runat="server">
<title></title>
</head>
<body>
<form id="form1" runat="server">
<div>
<cc1:MyCheckBox ID="MyCheckBox1" runat="server" />
</div>
</form>
</body>
</html>
最後に 1 つ: これは単純化のためです。すべてではないにしても、ほとんどの asp.net Web コントロールに、ビュー ステートを無効にする機能があることに気付く場合があります。ほとんどの場合、オンのままですが、要点はプログラマー次第です。カスタム コントロール プロパティを保存するための ViewState は、viewstate が有効になっている場合にのみ機能します。それを無効にして、LastValue に別れを告げましょう。より良い (適切な?) 方法は、Save/LoadControlState() メソッドをオーバーライドすることですが、それはより複雑なので、要件を実装する最善の方法を決定するのはあなたに任せます。
HTMLフォームで作業していると仮定すると、フォームに同様の名前の隠しフィールドを作成し、それにlastValueを入力し、それに対してチェックボックスをオンにします。
<input type="hidden" name="checkboxLastValue" value="true">