c# - 如何在 ASP.NET c# 中执行多个 ClientScript.RegisterStartupScript?

标签 c# asp.net response.write registerstartupscript clientscript

我正在开发一个 gridview,您可以在其中通过一个按钮下载多个文件。

这是我的 GridView :

<asp:GridView ID="grdvHistorialMensajes" runat="server" AllowPaging="True" 
                    AutoGenerateColumns="False" CellPadding="4" AllowSorting="true"
                    EmptyDataText="No Hay Mensajes Enviados" ForeColor="#333333" 
                    GridLines="None" CellSpacing="1" 
                    onpageindexchanging="grdvHistorialMensajes_PageIndexChanging" 
                    onrowcommand="grdvHistorialMensajes_RowCommand" 
                    onsorting="grdvHistorialMensajes_Sorting">
                    <AlternatingRowStyle BackColor="White" ForeColor="#284775" />

                    <Columns>
                        <asp:BoundField DataField="CorreoCliente" HeaderText="Correo Del Cliente" SortExpression="CorreoCliente" />
                        <asp:BoundField DataField="CorreosAdicionales" HeaderText="Correos Adicionales" SortExpression="CorreosAdicionales" />
                        <asp:BoundField DataField="Tema" HeaderText="Tema" SortExpression="Tema" />
                        <asp:BoundField DataField="Mensaje" HeaderText="Mensaje" SortExpression="Mensaje" />

                        <asp:TemplateField HeaderText="Fecha" SortExpression="Fecha">
                            <ItemTemplate>
                                <%# DataBinder.Eval(Container.DataItem, "Fecha", "{0:dd/MM/yyyy}")%>
                            </ItemTemplate>

                            <EditItemTemplate>
                                <asp:TextBox ID="tbxFecha" runat="server" Text='<%#Bind("Fecha","{0:dd/MM/yyyy}") %>' ValidationGroup="gpEdicionAgenda">
                                </asp:TextBox>
                            </EditItemTemplate>
                        </asp:TemplateField>

                        <asp:BoundField DataField="Hora" HeaderText="Hora" SortExpression="Hora" />
                        <asp:BoundField DataField="Archivos" HeaderText="Archivos" SortExpression="Archivos" />

                        <asp:TemplateField>
                            <ItemTemplate>
                                <asp:ImageButton ID="imgBtnDescargarArchivos" runat="server" 
                                    CommandArgument='<%# Eval("IdMensaje")%>' CommandName="Descargar" Height="16px" 
                                    ImageUrl="~/img/activar.png" ToolTip="Descargar" Width="16px" />
                            </ItemTemplate>
                        </asp:TemplateField>

                        <asp:TemplateField>
                            <ItemTemplate>
                                <asp:ImageButton ID="imgBtnVerMas" runat="server" 
                                    CommandArgument='<%# Eval("IdMensaje")%>' CommandName="VerMas" Height="16px" 
                                    ImageUrl="~/img/search.png" ToolTip="Ver Mas" Width="16px" />
                            </ItemTemplate>
                        </asp:TemplateField>
                    </Columns>

                    <EditRowStyle BackColor="#999999" />
                    <FooterStyle BackColor="#5D7B9D" Font-Bold="True" ForeColor="White" />
                    <HeaderStyle BackColor="#5D7B9D" Font-Bold="True" ForeColor="White" />
                    <PagerStyle BackColor="#284775" ForeColor="White" HorizontalAlign="Center" />
                    <RowStyle BackColor="#F7F6F3" ForeColor="#333333" HorizontalAlign="Center" />
                    <SelectedRowStyle BackColor="#E2DED6" Font-Bold="True" ForeColor="#333333" />
                    <SortedAscendingCellStyle BackColor="#E9E7E2" />
                    <SortedAscendingHeaderStyle BackColor="#506C8C" />
                    <SortedDescendingCellStyle BackColor="#FFFDF8" />
                    <SortedDescendingHeaderStyle BackColor="#6F8DAE" />
                </asp:GridView>

每当我单击“Descargar”RowCommand 时,我最初使用的是:

if (e.CommandName == "Descargar")
            {
                DataTable dt = ConexionBD.GetInstanciaConexionBD().GetArchivosPorMensaje(Convert.ToInt32(e.CommandArgument));

                foreach (DataRow dr in dt.Rows)
                {
                    string strArchivo = dr["Nombre"].ToString();
                    string strExtension = Path.GetExtension(strArchivo).ToLower();
                    Response.Write("<script>window.open('/Archivos/" + strArchivo + "');</script>");
                }
            }

当我单击时,如果该行有 1 个 pdf、1 个 jpg 和 1 个文档,它会在不同的窗口中同时打开 pdf 和 jpg,然后将下载文档。这正是我想要的。但是,我注意到每当打开一个新页面时(对于 pdf 和 jpg),页面中的所有字体都会被更改。所以我想找到一个解决方案,然后我尝试了这个:

if (e.CommandName == "Descargar")
            {
                DataTable dt = ConexionBD.GetInstanciaConexionBD().GetArchivosPorMensaje(Convert.ToInt32(e.CommandArgument));

                foreach (DataRow dr in dt.Rows)
                {
                    string strArchivo = dr["Nombre"].ToString();
                    string strExtension = Path.GetExtension(strArchivo).ToLower();
                    ClientScript.RegisterStartupScript(this.GetType(), "myFileOpenScript", "<script>window.open('/Archivos/" + strArchivo + "');</script>");
                }
            }

当我打开一个 pdf 文件时,这次字体没有改变,但是,它只会打开/下载出现 int dt.Rows[0] 的第一个文件(dt.Rows[1] on won't open ).我想 Response.Write 可以部署多次,但是 ClientScript.RegisterStartupScript 可能只能执行一次。

是否有另一种方法可以用来不改变页面的字母字体并通过单击打开多个文件?

或者如何多次执行 ClientScript.RegisterStartupScript?

提前致谢

最佳答案

一些额外的信息信息会有所帮助。您不会被限制多次使用 RegisterStatupScript,但您会被限制多次注册相同的类型/键组合(这是一项功能,而不是限制)。

如果您需要注册不同的脚本,请使用唯一的 key 。如果您只是进行回发,重新注册启动脚本将/应该可以工作。

http://msdn.microsoft.com/en-us/library/system.web.ui.clientscriptmanager.aspx

关于c# - 如何在 ASP.NET c# 中执行多个 ClientScript.RegisterStartupScript?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12534417/

相关文章:

c# - SQLite 将字符存储为字符串?

c# - 显示页面几秒钟并导航到另一个页面

asp.net - bundle 优先于路由吗?

asp.net - Response.Write 和 <%= %> 之间的实际区别是什么?

c# - 如何在 asp.net 中显示 response.write

c# - 我可以在用户控件内创建内联函数/方法吗?

c# - 对同一对象调用两次 MustHaveHappened 失败

c# - ASP.Net MVC 3 Razor Response.Write 位置

c# - 如何在 C# 中将数据从 Sqlserver 2008 数据库表插入 MS Access

.net - mscorlib.dll 中出现类型为 System.StackOverflowException 的未处理异常