`
yaoyao19851023
  • 浏览: 32174 次
  • 性别: Icon_minigender_2
  • 来自: 大连
最近访客 更多访客>>
社区版块
存档分类
最新评论

在网页中动态添加控件实例

阅读更多
在网页中动态添加控件的实例

在网页中经常要动态添加控件的方法,例如上传多个文件,而具体不知道上传多少个文件,通过添加附件按钮来动态添加FileUPLoad控件。具体做法:

第一种方法:在网页中添加一个Panel1容器控件。在Panel1的容器控件中添加FileUpLoad控件。

添加一个命令按钮Button1,Button1.Text="添加附件";

后台代码:

using System;
using System.Collections;
using System.Configuration;
using System.Data;
using System.Linq;
using System.Web;
using System.Web.Security;
using System.Web.UI;
using System.Web.UI.HtmlControls;
using System.Web.UI.WebControls;
using System.Web.UI.WebControls.WebParts;
using System.Xml.Linq;

public partial class Blog_NewBlog : System.Web.UI.Page
{
    protected void Page_Load(object sender, EventArgs e)
    {
        if (!IsPostBack)
        {
            ViewState["nClick"] = 0;//定义ViewState.
        }
    }

    private void LoadFileupLoad(int n)//创建自定义方法,用于添加FileUpLoad控件。
    {
     
        FileUpload imgfile = new FileUpload();
        imgfile.ID = "FileUpload" + n.ToString().Trim();
        imgfile.Width = 500;
        this.Panel2.Controls.Add(imgfile);
    }

    protected void Button1_Click(object sender, EventArgs e)//添加附件按钮事件
    {
        if (ViewState["nClick"] != null)
        {
            for (int i = 0; i <= Convert.ToInt32(ViewState["nClick"].ToString()); i++)
            {
                LoadFileupLoad(i);//调用自定义方法。
            }
            ViewState["nClick"] = Convert.ToInt32(ViewState["nClick"].ToString()) + 1;//ViewState加1
        }
          
    }

    //引用动态添加的FileUpload控件,把上传的文件保存到服务器上,把文件信息存储到数据库中。

    protected void Button8_Click(object sender, EventArgs e)
    {
        OA jkj = new OA();//自定义类
        bool ok = false;//上传的文件是否符合要求
        string Ftype = "";//文件类型。
        string[] kzm = new string[] { ".jpg", ".tif", ".pdf", ".doc", ".xls", ".txt", ".ppt",".rar" };//上传的文件类型
        bool cb = false;//存储插入数据的成功标记。
        jkj.StroeProName = "UP_BlogInsert";//存储过程名称
        jkj.TableName = "Blog";//保存记录的表名称。
        string bid = Guid.NewGuid().ToString();//生成一个唯一标识。
        string gk = "";
        if (RadioButton1.Checked == true)
        {
            gk = "公开";
        }
        else
        {
            gk = "私人";
        }
      
        string[,] sql = new string[,]
        {
            {"@xm",Profile.xm,"InPut"},
            {"@Btitle",jkj.HtmlCode(TextBox1.Text),"InPut"},
            {"@Bcontent",FreeTextBox1.Text,"InPut"},
            {"@ClassID",DropDownList1.SelectedValue,"InPut"},
          
            {"@Bid",bid,"InPut"},
            {"@state",gk,"InPut"},
            {"@sendto",TextBox2.Text,"InPut"}
        };
        if (jkj.ExeComm(sql, "1") == "0")
        {
            cb = true;//保存成功。

        }
        HttpFileCollection files = Request.Files;//获取动态控件FileUpload的集合。
        string fileName;//文件名
        int fsize = 0;//文件的大小
        for (int i = 0; i < files.Count; i++)
        {
            if (files[i].ContentLength <= 0)
                continue;
            Ftype = System.IO.Path.GetExtension(files[i].FileName);
            fsize = files[i].ContentLength;
            for (int x = 0; x < kzm.Length; x++)
            {
                if (Ftype.ToLower() == kzm[x])
                    ok = true;
            }
            if (ok == true)
            {
                string upfilename = DateTime.Now.ToString("yyyymmddhhmmss") + Ftype;
                string webpath = Server.MapPath("~/blog/upfiles/");
                files[i].SaveAs(webpath + upfilename);//保存上传的文件到服务器
                jkj.StroeProName = "UP_BlogFile";
                jkj.TableName = "BlogFile";
                string[,] bf = new string[,]
                    {
                        {"@bid",bid,"InPut"},
                        {"@fName",upfilename,"InPut"},
                        {"@ftype",Ftype,"InPut"},
                        {"@fsize",fsize.ToString(),"InPut"}
                    };
                if (jkj.ExeComm(bf, "1") == "0" && cb == true)
                {
                    jkj.Show("保存成功!");
                }

            }
            else
            {
                jkj.Show("上传的文件格式符合要求!");
            }
        }
    }        

}



第二种方法:使用JavaScript

页面如下:

《HTML>
     《HEAD>
     <script>          
     function AddAttachments()            {                
     document.getElementById('attach').innerText = "继续添加附件";                                  
     tb = document.getElementById('attAchments');                                  
     newRow = tb.insertRow();                
     newRow.insertCell().innerHTML = "<input name='File' size='50' type='file'>&nbsp;&nbsp;<input type=button value='删除' onclick='delFile(this.parentElement.parentElement.rowIndex)'>";          
     }          
     function delFile(index)          
     {                
     document.getElementById('attAchments').deleteRow(index);                
     tb.rows.length > 0?document.getElementById('attach').innerText = "继续添加附件":document.getElementById('attach').innerText = "添加附件";          
     }          
     </script>    
     </HEAD>    
     <body MS_POSITIONING="GridLayout">          
     <form id="form1" method="post" runat="server" enctype="multipart/form-data">          
     <div><table id="attAchments"></table></div><span><IMG src="icoAddFl.gif"> </span> <A id="attach" style="font-family:宋体;font-size:9pt;" title="如果您要发送多个附件,您只需多次点击“继续添加附件”即可, 要注意附件总量不能超过发送限制的大小。" onclick="AddAttachments();" href="javascript:;" name="attach">添加附件</A>
     <br><br><br><br><br><br>                
<asp:Button id="btnSend" runat="server" Text=" 上传 " onclick="btnSend_Click"></asp:Button>          
</form>    
《/body>《/HTML>

后台代码

protected void btnSend_Click(object sender, EventArgs e)
    {
        StringBuilder sb = new StringBuilder();

        int attCount = 0;
        string filePath = "";
        for (int i = 0; i < Request.Files.Count; i++)
        {
            if (Request.Files[i].ContentLength > 0)
            {
                filePath = Request.Files[i].FileName;
                sb.Append("Files" + attCount++ + ": " + filePath + "<br>");
                Request.Files[0].SaveAs(Server.MapPath("./") + filePath.Substring(filePath.LastIndexOf("\\") + 1));
            }
        }
        sb.Insert(0, "you upload " + attCount + " files.<br>"); Response.Write(sb.ToString());
    }
分享到:
评论

相关推荐

    在网页中动态添加自定义用户控件

    3. **动态添加**:在服务器端代码(如.aspx.cs文件)中,我们可以使用`Page.LoadControl()`方法动态创建用户控件实例。然后,通过`PlaceHolder`或`Panel`等容器控件的`Controls.Add()`方法将其添加到页面的某个位置...

    ASP.NET自定义控件实例教程

    在"ASP.NET自定义控件实例教程.pdf"中,你将找到详细的操作指南和代码示例,涵盖了以上各个关键点。通过实际操作,你将学会如何创建自定义控件,如何进行数据绑定,以及如何优化性能。此外,教程还可能包括如何调试...

    Android各种常用控件实例程序集合

    通过这些实例,开发者不仅可以了解如何在XML布局文件中声明控件,还能学习如何在Java代码中动态创建和操作它们。此外,还会涉及到布局管理器(如LinearLayout、RelativeLayout、ConstraintLayout)的使用,以及如何...

    webChart控件实例

    在这个实例中,可能包含了一些初始化WebChart控件所需的数据源或者设置全局的配置。 接着,`WebForm19.aspx`到`WebForm18.aspx`这些文件代表了不同的网页示例,每个页面可能展示了WebChart控件的不同用法。例如,`...

    c#.netweb页面嵌入excel控件,网页中在线编辑EXCEL表格实例

    在这个实例中,我们可能使用了某种第三方控件,如Aspose.Cells,它提供了对Excel文件的强大支持,包括读写、格式化、公式计算等功能。开发者可以通过API将Excel控件嵌入到ASP.NET的WebForm(aspx页面)中,实现在线...

    gridview控件使用实例源代码

    2. **添加GridView控件**:在ASP.NET页面上添加GridView控件,并通过拖放操作或在代码中创建实例。 3. **数据绑定**:将数据源与GridView控件绑定,可以通过`GridView1.DataSource = 数据源对象;`和`GridView1....

    web动态加载用户控件

    在Web应用程序中,用户控件(User Control)是一种可重用的自定义组件,它们可以被设计、编码并集成到网页中,以实现特定的功能。本篇将深入探讨“web动态加载用户控件”的概念、方法以及在C#中的实现。 一、用户...

    ASP.NET源码——动态添加表格实例.zip

    在本实例中,我们将探讨如何在ASP.NET中动态地添加表格,这通常涉及到HTML控件、服务器端代码以及数据绑定的概念。 在ASP.NET中,动态创建控件是常见的需求,特别是在需要根据用户输入或者数据库数据动态生成界面的...

    ztree树形控件实例

    《zTree树形控件实例解析与应用》 在网页开发中,树形控件是一种常见且实用的用户界面元素,它能够清晰地展示层级关系数据,如文件系统、组织结构等。zTree是一款基于JavaScript的开源树形控件,它结合了ajax和json...

    asp.net-datagrid控件实例

    ASP.NET是微软开发的一种Web应用程序框架,用于构建动态网站、Web应用和...以上就是关于"asp.net-datagrid控件实例"的详细说明,涵盖了`DataGrid`控件的基本使用、数据绑定、自定义显示、以及性能优化等方面的知识点。

    ajax控件实例包含差不多所有ajax控件的实例代码

    Ajax(Asynchronous JavaScript and XML)是一种在无需重新加载整个网页的情况下,能够更新部分网页...通过深入学习和实践这些Ajax控件实例,开发者不仅可以掌握Ajax技术,还能提高构建动态、响应式Web应用程序的能力。

    web具体的实例是关于控件的

    【标题】中的"web具体的实例是关于控件的",意味着我们将探讨Web开发中的控件使用,这在构建用户界面时至关重要。控件是Web应用程序交互性的基础,它们允许用户输入数据、触发操作或导航页面。 【描述】指出这是一...

    WEB 打印控件及实例

    "WEB 打印控件"是一种技术解决方案,它允许开发者添加到网页中,使得用户无需离开浏览器就能进行打印操作。这种控件通常是一个动态链接库(DLL)或者ActiveX组件,它可以被嵌入到HTML页面中,为用户提供友好的打印...

    winform拖拽调整动态控件大小实例

    在这个实例中,我们将探讨如何使用`DotNetBar2`来实现拖拽调整控件大小的功能。 首先,`DotNetBar2`是 DevComponents公司开发的一个组件集,它包含了许多预设的皮肤、工具栏、菜单、对话框等元素,能够帮助开发者...

    js日历控件实例源码

    在这个"js日历控件实例源码"中,我们有两个关键文件:`demo.html`和`setday.js`。 首先,`demo.html`是示例页面,它包含了控件的展示和交互界面。在HTML文件中,我们可以看到一个用于显示日历的占位符元素,通常是...

    基于ASP.NET+C#实现Web网页动态切换加载用户控件程序例子

    在动态加载用户控件时,我们首先需要在服务器端代码中创建用户控件的实例。这通常在Page_Load事件中完成,或者根据用户的交互(如点击按钮)来触发。例如,可以使用以下代码创建一个名为"DynamicControl.ascx"的用户...

    一些jQuery粉色风格的常用网页控件实例.rar

    在这个实例中,jQuery被用来增强网页元素的交互性,比如通过添加动态效果使按钮更吸引用户,或者在用户输入文本时实时更新字数统计。 单选框和按钮是网页表单的基本组成部分。在粉色主题下,这些控件的样式可以通过...

    在ASP.NET 2.0中使用页面导航控件实例有源码

    而在asp.net 2.0中,为了方便进行页面导航,新增了一个叫做页面导航控件sitemapdatasource,sitemapdatasource中还可以绑定到不同的其他页面控件,比如treeview,menu等,十分灵活,使到能很方便地实现页面导航的不同...

Global site tag (gtag.js) - Google Analytics