繁体   English   中英

如何在gridview(asp.net)进入更新模式之前刷新整个页面?

[英]How to refresh whole page before going into update mode in gridview(asp.net)?

我有一个网站,管理员可以在其中删除或添加新的gridview。 例如,如果我当前拥有giordano产品的gridview,并且想要将品牌更改为bossini产品。 当管理员单击“编辑”按钮时,应该删除giordano产品的整个gridview和代码,如果我已经处于更新模式,并将品牌名称更改为“ bossini”并单击“ update”,则应该为bossini产品添加新的gridview和代码。

现在是问题所在。 当我单击编辑按钮时,它将删除整个gridview代码,但gridview本身仍显示在网站中。 我终于知道我需要刷新页面,但是我还不知道最好的方法。 我已经在GuitarBrandsGridView_RowEditing中尝试过Response.Redirect(“ urls”),但是它不起作用,给了我一个例外。 它适用于GuitarBrandsGridView_RowDeleting。 我只是假设它可能对我的编辑按钮有效,但是失败了。

我的目标是,当我单击gridview中的“编辑”按钮时,整个网页应该刷新,然后进入更新模式。 希望这是有道理的。

protected void Page_Load(object sender, EventArgs e)
{
    if (!IsPostBack) {
        bindgridviewguitarbrands();
        BindGridViewDataList.GetItemsLoad();
    }
}

//Start of Gridview Code for Guitar Brands
private void bindgridviewguitarbrands()
{
    con1.Open();
    cmd1.CommandText = "SELECT * FROM [guitarBrands]";
    cmd1.Connection = con1;
    SqlDataAdapter da1 = new SqlDataAdapter(cmd1);
    da1.Fill(ds1);
    con1.Close();
    GuitarBrandsGridView.DataBind();

}

protected void GuitarBrandsGridView_RowDataBound(object sender, GridViewRowEventArgs e)
{
    if (e.Row.RowType == DataControlRowType.DataRow)
    {
        string name = Convert.ToString(DataBinder.Eval(e.Row.DataItem, "Name"));
        Button button = (Button)e.Row.FindControl("GuitarBrandsGridViewBtnDelete");
        button.Attributes.Add("onclick", "JavaScript:return ConfirmationBox('" + name + "' )");
    }
}

protected void GuitarBrandsGridView_RowDeleting(object sender, GridViewDeleteEventArgs e)
{

    int id = Convert.ToInt32(GuitarBrandsGridView.DataKeys[e.RowIndex].Value.ToString());
    Label name = (Label)GuitarBrandsGridView.Rows[e.RowIndex].FindControl("lblName");

    RemoveCodeToGuitarFile.RemoveAddGuitarClass(name.Text);
    RemoveCodeToGuitarFile.RemoveConnectionClassGuitarItems(name.Text);
    RemoveCodeToGuitarFile.RemoveOverviewGuitarDataASPX(name.Text);
    RemoveCodeToGuitarFile.RemoveOverviewGuitarDataCode(name.Text);
    File.Delete(@"C:\Users\User1\Documents\Visual Studio 2015\WebSites\MusicStore\Pages\GuitarItems" + id + ".aspx");
    File.Delete(@"C:\Users\User1\Documents\Visual Studio 2015\WebSites\MusicStore\Pages\GuitarItems" + id + ".aspx.cs");
    ConnectionClassGuitarBrands.RemoveGuitarBrandsDatabase(name.Text);

    con1.Open();
    cmd1.CommandText = "DELETE FROM [guitarBrands] WHERE id=" + id;
    cmd1.Connection = con1;
    int a = cmd1.ExecuteNonQuery();

    con1.Close();

    if (a > 0) {
        bindgridviewguitarbrands();
    }

    Response.Redirect("~/Pages/OverviewGuitarData.aspx");

}

protected void GuitarBrandsGridView_RowEditing(object sender, GridViewEditEventArgs e)
{
    GuitarBrandsGridView.EditIndex = e.NewEditIndex;
    string id = GuitarBrandsGridView.DataKeys[e.NewEditIndex].Value.ToString();
    Label name = (Label)GuitarBrandsGridView.Rows[e.NewEditIndex].FindControl("lblName");

    RemoveCodeToGuitarFile.RemoveAddGuitarClass(name.Text);
    RemoveCodeToGuitarFile.RemoveConnectionClassGuitarItems(name.Text);
    RemoveCodeToGuitarFile.RemoveOverviewGuitarDataASPX(name.Text);
    RemoveCodeToGuitarFile.RemoveOverviewGuitarDataCode(name.Text);
    File.Delete(@"C:\Users\User1\Documents\Visual Studio 2015\WebSites\MusicStore\Pages\GuitarItems" + id + ".aspx");
    File.Delete(@"C:\Users\User1\Documents\Visual Studio 2015\WebSites\MusicStore\Pages\GuitarItems" + id + ".aspx.cs");
    ConnectionClassGuitarBrands.RemoveGuitarBrandsDatabase(name.Text);       

    bindgridviewguitarbrands();
    Response.Redirect("~/Pages/OverviewGuitarData.aspx");//this one is not working
}
// row update event
protected void GuitarBrandsGridView_RowUpdating(object sender, GridViewUpdateEventArgs e)
{
    // find student id of edit row
    string id = GuitarBrandsGridView.DataKeys[e.RowIndex].Value.ToString();
    // find updated values for update
    TextBox type = (TextBox)GuitarBrandsGridView.Rows[e.RowIndex].FindControl("txtType");
    TextBox name = (TextBox)GuitarBrandsGridView.Rows[e.RowIndex].FindControl("txtName");
    TextBox image = (TextBox)GuitarBrandsGridView.Rows[e.RowIndex].FindControl("txtImage");


    cmd1 = new SqlCommand("UPDATE [guitarBrands] SET Type = '" + type.Text + "', Name = '" + name.Text + "', Image = '" + image.Text + "' WHERE ID = " + id, con1);
    con1.Open();
    cmd1.ExecuteNonQuery();
    con1.Close();

    int ID = Convert.ToInt32(id);
    ConnectionClassGuitarBrands.CreateGuitarBrandsDatabase(name.Text);
    AddCodeToGuitarFile.AddGuitarClassCode(name.Text, ID);
    AddCodeToGuitarFile.AddConnectionClassGuitarItems(name.Text);
    AddCodeToGuitarFile.AddOverviewGuitarDataASPX(name.Text, ID);
    AddCodeToGuitarFile.AddOverviewGuitarDataASPXCode(name.Text);
    AddASPXAndCSFileForGuitarBrands.AddFile(name.Text, ID);

    GuitarBrandsGridView.EditIndex = -1;
    bindgridviewguitarbrands();

}
// cancel row edit event
protected void GuitarBrandsGridView_RowCancelingEdit(object sender, GridViewCancelEditEventArgs e)
{
    string id = GuitarBrandsGridView.DataKeys[e.RowIndex].Value.ToString();
    TextBox name = (TextBox)GuitarBrandsGridView.Rows[e.RowIndex].FindControl("txtName");

    int ID = Convert.ToInt32(id);
    ConnectionClassGuitarBrands.CreateGuitarBrandsDatabase(name.Text);
    AddCodeToGuitarFile.AddGuitarClassCode(name.Text, ID);
    AddCodeToGuitarFile.AddConnectionClassGuitarItems(name.Text);
    AddCodeToGuitarFile.AddOverviewGuitarDataASPX(name.Text, ID);
    AddCodeToGuitarFile.AddOverviewGuitarDataASPXCode(name.Text);
    AddASPXAndCSFileForGuitarBrands.AddFile(name.Text,ID);

    GuitarBrandsGridView.EditIndex = -1;
    bindgridviewguitarbrands();
}

您无需刷新整个页面

GuitarBrandsGridView.DataSource = ds1
GuitarBrandsGridView.DataBind();

然后将更新新数据

Response.Redirect("http://localhost:14999/Home/Index");

您希望页面刷新的位置需要提供页面的完整路径,它将重新加载该页面。 我希望它会为我工作

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM