1

ActiveTabChangedの発射方法TabContainerTabPanelデータベースから HeaderText を設定するコードを作成しました。これが私のコードです

public partial class dynamicTab : System.Web.UI.Page
{
    string strCon = ConfigurationManager.ConnectionStrings["SqlCon"].ConnectionString.ToString();
    TabContainer ajxTab;

    protected void Page_Load(object sender, EventArgs e)
    {
        if (!IsPostBack)
        {
           // createTab();
            pnlDynamic.Controls.Add(ajxTab);
            ajxTab_ActiveTabChanged(ajxTab, EventArgs.Empty);
        }
    }

    private void ajxTab_ActiveTabChanged(TabContainer ajxTab, EventArgs eventArgs)
    {
        SqlConnection con = new SqlConnection(strCon);
        SqlCommand cmd = new SqlCommand("select * from Employee where DeptID='" + ajxTab.ActiveTab.ID.ToString() + "'", con);
        con.Open();
        SqlDataAdapter da = new SqlDataAdapter();
        da.SelectCommand = cmd;
        DataSet ds = new DataSet();
        da.Fill(ds);

        GridView grd = new GridView();
        grd.AutoGenerateColumns = true;
        grd.DataSource = ds;
        grd.DataBind();
        pnlDynamic.Controls.Add(grd);
    }

    protected void page_init(object sender, eventargs e)
    {
        createtab();

    }

    private void createTab()
    {
        SqlConnection con = new SqlConnection(strCon);
        SqlCommand cmd = new SqlCommand("select DeptID,DepartmentName from Department", con);
        con.Open();
        SqlDataAdapter da = new SqlDataAdapter();
        da.SelectCommand = cmd;
        DataSet ds = new DataSet();
        da.Fill(ds);
        ajxTab = new AjaxControlToolkit.TabContainer();
        for (int i = 0; i < ds.Tables[0].Rows.Count; i++)
        {
            TabPanel pnl = new TabPanel();
            pnl.HeaderText = ds.Tables[0].Rows[i]["DepartmentName"].ToString();
            pnl.ID = ds.Tables[0].Rows[i]["DeptID"].ToString();
            ajxTab.Tabs.Add(pnl);
            ajxTab.ActiveTabIndex = 0;
        }
    }
}

初めてActiveTabChanged完全に起動しましたが、2番目のタブをクリックするとActiveTabChanged起動しません。設定してみましたajxTab.AutoPostBack=trueが、イベント発生時にタブコンテナが表示されません。

これは私のサンプル出力です

ここに画像の説明を入力

コンピューターをクリックすると、グリッドにそれらの詳細をロードしたいので、誰か助けてください

4

1 に答える 1

0

OnActiveTabChanged イベントで各タブのコンテンツをバインドできます

OnActiveTabChanged="TabContainer1_ActiveTabChanged" AutoPostBack="true"

于 2012-12-21T08:36:50.500 に答える