gridview按钮列的下载功能

    protected void GridView1_RowCommand(object sender, GridViewCommandEventArgs e)
    {
       
//这里是模板列里面的按钮,需要设置CommandArgument ="<%# GridView1.Rows.Count %>",否则出错
        if (e.CommandName == "Download")
        {
            FileDownload(
@"F:\music\6-渴望.mp3");
        }
    }

   
private void FileDownload(string FullFileName)
    {
        FileInfo DownloadFile
= new FileInfo(FullFileName);
        Response.Clear();
        Response.ClearContent();
        Response.ClearHeaders();
        Response.Buffer
= false;
        Response.ContentType
= "application/octet-stream";
        Response.AppendHeader(
"Content-Disposition", "attachment;filename=" + HttpUtility.UrlEncode(DownloadFile.FullName, System.Text.Encoding.UTF8));
        Response.AppendHeader(
"Content-Length", DownloadFile.Length.ToString());
        Response.AddHeader(
"Content-Transfer-Encoding", "binary");
        Response.ContentEncoding
= System.Text.Encoding.GetEncoding("UTF-8");
        Response.WriteFile(DownloadFile.FullName);
        Response.Flush();
        Response.End();
    }

注意:

  如果是在GridView在UpdatePanel下,就需要加入如下代码:

  <Triggers>
     
<asp:PostBackTrigger ControlID="GridView1" />
  </Triggers>

  否则会报错

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 在WPF中,要为表控件的头添加折叠按钮,可以使用自定义控件模板来实现。 首先,创建一个自定义控件模板,例如: ```XAML <ControlTemplate x:Key="ColumnHeaderTemplate" TargetType="{x:Type GridViewColumnHeader}"> <Grid> <Grid.ColumnDefinitions> <ColumnDefinition Width="Auto"/> <ColumnDefinition Width="*"/> </Grid.ColumnDefinitions> <ToggleButton x:Name="ToggleBtn" Grid.Column="0" Width="20" Height="20" Content="▲" VerticalAlignment="Center" Click="ToggleBtn_Click"/> <ContentPresenter Grid.Column="1" Content="{TemplateBinding Content}" VerticalAlignment="Center"/> </Grid> </ControlTemplate> ``` 然后,将这个自定义控件模板应用到表控件的头,例如: ```XAML <ListView> <ListView.View> <GridView> <GridViewColumn HeaderContainerStyle="{StaticResource ColumnHeaderStyle}" HeaderTemplate="{StaticResource ColumnHeaderTemplate}" DisplayMemberBinding="{Binding PropertyName1}"/> <GridViewColumn HeaderContainerStyle="{StaticResource ColumnHeaderStyle}" HeaderTemplate="{StaticResource ColumnHeaderTemplate}" DisplayMemberBinding="{Binding PropertyName2}"/> </GridView> </ListView.View> </ListView> ``` 最后,在代码中实现折叠按钮的点击事件,例如: ```C# private void ToggleBtn_Click(object sender, RoutedEventArgs e) { ToggleButton toggleBtn = sender as ToggleButton; GridViewColumnHeader columnHeader = toggleBtn.TemplatedParent as GridViewColumnHeader; if (toggleBtn.IsChecked == true) { // 隐藏 columnHeader.Visibility = Visibility.Collapsed; } else { // 显示 columnHeader.Visibility = Visibility.Visible; } } ``` 这样,就可以通过点击头上的折叠按钮来隐藏或显示该了。当按钮被点击时,会触发ToggleBtn_Click事件,根据ToggleBtn的IsChecked属性来判断是隐藏还是显示头。 ### 回答2: 在WPF中,可以通过自定义控件模板来实现头添加折叠按钮功能。 首先,需要使用一个带有折叠按钮的ToggleButton控件作为头的模板。可以使用样式来定义这个控件的外观和交互行为。 接下来,在DataGrid控件中设置头的模板,可以通过设置DataGrid.ColumnHeaderStyle属性来实现。 在样式的模板中,可以使用Grid或者其他布局控件来布局头的内容和折叠按钮。可以使用触发器来控制折叠按钮的显示和隐藏。 在折叠按钮的Click事件中,可以处理相应的逻辑,比如修改头的显示或者隐藏状态。 最后,可以使用绑定来实现动态控制头的折叠状态,可以绑定到相应的属性或者命令。 总结起来,通过自定义控件模板、样式、布局和绑定,可以在WPF中实现头添加折叠按钮功能。具体的实现方式可以根据具体需求进行调整和扩展。 ### 回答3: 在WPF中,要为表头添加折叠按钮,可以通过使用ListView控件的GridView头模板来实现。 首先,在ListView的XAML代码中,我们需要定义GridView头模板。可以使用Grid或者其他类似容器来组织内容。在这个模板中,我们可以添加一个Button控件作为折叠按钮,以及显示标题的TextBlock控件。例如: ``` <ListView> <ListView.View> <GridView> <GridViewColumn> <GridViewColumnHeader> <Grid> <Button Width="20" Height="20" Click="Button_Click"> <Button.Content> <Image Source="collapse.png" /> </Button.Content> </Button> <TextBlock Text="标题"/> </Grid> </GridViewColumnHeader> <GridViewColumn.CellTemplate> <DataTemplate> ... </DataTemplate> </GridViewColumn.CellTemplate> </GridViewColumn> </GridView> </ListView.View> </ListView> ``` 在这个例子中,我们为头添加了一个Button按钮,并为按钮添加了点击事件处理程序`Button_Click`。当按钮被点击时,可以编写相关的C#代码来实现折叠效果。例如,可以使用VisualStateManager来改变按钮的外观,同时收起或展开相应的内容。 在C#代码中,我们可以定义`Button_Click`事件处理程序,然后在事件处理程序中根据需要更新相关的界面元素。 需要注意的是,折叠效果的具体实现方式可以根据实际需求进行调整。例如,可以使用其他控件替代按钮,或者使用自定义的样式和动画效果来实现更加复杂的折叠效果。以上代码仅为示例,具体实现方式可以根据项目需要进行调整。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值