在网页中动态添加控件的实例
在网页中经常要动态添加控件的方法,例如上传多个文件,而具体不知道上传多少个文件,通过添加附件按钮来动态添加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'> <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自定义控件实例教程.pdf"中,你将找到详细的操作指南和代码示例,涵盖了以上各个关键点。通过实际操作,你将学会如何创建自定义控件,如何进行数据绑定,以及如何优化性能。此外,教程还可能包括如何调试...
通过这些实例,开发者不仅可以了解如何在XML布局文件中声明控件,还能学习如何在Java代码中动态创建和操作它们。此外,还会涉及到布局管理器(如LinearLayout、RelativeLayout、ConstraintLayout)的使用,以及如何...
在这个实例中,可能包含了一些初始化WebChart控件所需的数据源或者设置全局的配置。 接着,`WebForm19.aspx`到`WebForm18.aspx`这些文件代表了不同的网页示例,每个页面可能展示了WebChart控件的不同用法。例如,`...
在这个实例中,我们可能使用了某种第三方控件,如Aspose.Cells,它提供了对Excel文件的强大支持,包括读写、格式化、公式计算等功能。开发者可以通过API将Excel控件嵌入到ASP.NET的WebForm(aspx页面)中,实现在线...
2. **添加GridView控件**:在ASP.NET页面上添加GridView控件,并通过拖放操作或在代码中创建实例。 3. **数据绑定**:将数据源与GridView控件绑定,可以通过`GridView1.DataSource = 数据源对象;`和`GridView1....
在Web应用程序中,用户控件(User Control)是一种可重用的自定义组件,它们可以被设计、编码并集成到网页中,以实现特定的功能。本篇将深入探讨“web动态加载用户控件”的概念、方法以及在C#中的实现。 一、用户...
在本实例中,我们将探讨如何在ASP.NET中动态地添加表格,这通常涉及到HTML控件、服务器端代码以及数据绑定的概念。 在ASP.NET中,动态创建控件是常见的需求,特别是在需要根据用户输入或者数据库数据动态生成界面的...
《zTree树形控件实例解析与应用》 在网页开发中,树形控件是一种常见且实用的用户界面元素,它能够清晰地展示层级关系数据,如文件系统、组织结构等。zTree是一款基于JavaScript的开源树形控件,它结合了ajax和json...
ASP.NET是微软开发的一种Web应用程序框架,用于构建动态网站、Web应用和...以上就是关于"asp.net-datagrid控件实例"的详细说明,涵盖了`DataGrid`控件的基本使用、数据绑定、自定义显示、以及性能优化等方面的知识点。
Ajax(Asynchronous JavaScript and XML)是一种在无需重新加载整个网页的情况下,能够更新部分网页...通过深入学习和实践这些Ajax控件实例,开发者不仅可以掌握Ajax技术,还能提高构建动态、响应式Web应用程序的能力。
【标题】中的"web具体的实例是关于控件的",意味着我们将探讨Web开发中的控件使用,这在构建用户界面时至关重要。控件是Web应用程序交互性的基础,它们允许用户输入数据、触发操作或导航页面。 【描述】指出这是一...
"WEB 打印控件"是一种技术解决方案,它允许开发者添加到网页中,使得用户无需离开浏览器就能进行打印操作。这种控件通常是一个动态链接库(DLL)或者ActiveX组件,它可以被嵌入到HTML页面中,为用户提供友好的打印...
在这个实例中,我们将探讨如何使用`DotNetBar2`来实现拖拽调整控件大小的功能。 首先,`DotNetBar2`是 DevComponents公司开发的一个组件集,它包含了许多预设的皮肤、工具栏、菜单、对话框等元素,能够帮助开发者...
在这个"js日历控件实例源码"中,我们有两个关键文件:`demo.html`和`setday.js`。 首先,`demo.html`是示例页面,它包含了控件的展示和交互界面。在HTML文件中,我们可以看到一个用于显示日历的占位符元素,通常是...
在动态加载用户控件时,我们首先需要在服务器端代码中创建用户控件的实例。这通常在Page_Load事件中完成,或者根据用户的交互(如点击按钮)来触发。例如,可以使用以下代码创建一个名为"DynamicControl.ascx"的用户...
在这个实例中,jQuery被用来增强网页元素的交互性,比如通过添加动态效果使按钮更吸引用户,或者在用户输入文本时实时更新字数统计。 单选框和按钮是网页表单的基本组成部分。在粉色主题下,这些控件的样式可以通过...
而在asp.net 2.0中,为了方便进行页面导航,新增了一个叫做页面导航控件sitemapdatasource,sitemapdatasource中还可以绑定到不同的其他页面控件,比如treeview,menu等,十分灵活,使到能很方便地实现页面导航的不同...