asp.net 6.aspx页面
1.aspx页面的头部
<%@ Page Language="C#" AutoEventWireup="true" CodeBehind="UserInfoList.aspx.cs"
Inherits="CZBK.ItcastProject.WebApp.aspx_Demo.UserInfoList" %>
<%@ Import Namespace="CZBK.ItcastProject.Model" %>
**<%@ Page %>:页面本身也是一个对象,继承自Page,而<%@ Page %> 就是设置这个对象的属性用的。
**Language:C#语言
**AutoEventWireup:启动页面事件
**CodeBehind:代码后置,代码分离
**Inherits:继承。 aspx文件会生成一个(子类)类继承于 aspx.cs文件生成的(父类)类。
**<%@ Import Namespace="CZBK.ItcastProject.Model" %>:引用命名空间
2.aspx 和 aspx.cs
aspx文件会生成一个子类,aspx.cs文件会生成一个父类。aspx继承于aspx.cs
*在aspx.cs文件中生成一个公共属性,aspx文件可以访问到!
*在aspx.cs页面中使用C#代码,引用命名空间:<%@ Import Namespace="CZBK.ItcastProject.Model" %>;然后<%= %> 编写C#代码,‘=’ 是response.write
UserInfoList.aspx.cs
using CZBK.ItcastProject.Model;
using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.UI;
using System.Web.UI.WebControls; namespace CZBK.ItcastProject.WebApp.aspx_Demo
{
public partial class UserInfoList : System.Web.UI.Page
{
public string StrHtml { get; set; }
public List<UserInfo> UserList { get; set; } /// <summary>
/// 页面加载完成以后。Load事件 Form_Load
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
protected void Page_Load(object sender, EventArgs e)
{ }
}
}
UserInfoList.aspx
<%@ Page Language="C#" AutoEventWireup="true" CodeBehind="UserInfoList.aspx.cs" Inherits="CZBK.ItcastProject.WebApp.aspx_Demo.UserInfoList" %>
<%@ Import Namespace="CZBK.ItcastProject.Model" %>
<!DOCTYPE html> <html xmlns="http://www.w3.org/1999/xhtml">
<head runat="server">
<meta http-equiv="Content-Type" content="text/html; charset=utf-8"/>
<title></title>
<link href="../Css/tableStyle.css" rel="stylesheet" />
</head>
<body>
<form id="form1" runat="server">
<div>
<table> <tr><th>编号</th><th>用户名</th><th>密码</th><th>邮箱</th><th>时间</th><th>删除</th><th>详细</th><th>编辑</th></tr>
<%=StrHtml%>
<% foreach(UserInfo userInfo in UserList){%>
<tr>
<td><%=userInfo.Id %></td>
<td><%=userInfo.UserName %></td>
<td><%=userInfo.UserPass %></td>
<td><%=userInfo.Email %></td>
<td><%=userInfo.RegTime.ToShortDateString() %></td>
<td><a href="Delete.ashx?id=<%=userInfo.Id %>" class="deletes">删除</a></td>
<td>详细</td>
<td><a href="EditUser.aspx?id=<%=userInfo.Id %>">编辑</a> </td>
</tr> <%} %>
</table>
<hr />
</div>
</form>
</body>
</html>
3.Page_Load 方法
*页面加载完成触发(服务端的)
*aspx.cs中的 Page_Load 方法比aspx中的 window.onload = function () {} 方法要先执行!
4.aspx列表展示数据
UserInfoList.aspx:
1.引用命名空间
2.遍历父类的userInfo(list集合) 公共属性,循环生成一行tr
3.注意html代码可以结合C#代码编写在aspx中
<%@ Page Language="C#" AutoEventWireup="true" CodeBehind="UserInfoList.aspx.cs" Inherits="CZBK.ItcastProject.WebApp.aspx_Demo.UserInfoList" %>
<%@ Import Namespace="CZBK.ItcastProject.Model" %>
<!DOCTYPE html> <html xmlns="http://www.w3.org/1999/xhtml">
<head runat="server">
<meta http-equiv="Content-Type" content="text/html; charset=utf-8"/>
<title></title>
<link href="../Css/tableStyle.css" rel="stylesheet" />
</head>
<body>
<form id="form1" runat="server">
<div>
<table> <tr><th>编号</th><th>用户名</th><th>密码</th><th>邮箱</th><th>时间</th><th>删除</th><th>详细</th><th>编辑</th></tr>
<% foreach(UserInfo userInfo in UserList){%>
<tr>
<td><%=userInfo.Id %></td>
<td><%=userInfo.UserName %></td>
<td><%=userInfo.UserPass %></td>
<td><%=userInfo.Email %></td>
<td><%=userInfo.RegTime.ToShortDateString() %></td>
<td><a href="Delete.ashx?id=<%=userInfo.Id %>" class="deletes">删除</a></td>
<td>详细</td>
<td><a href="EditUser.aspx?id=<%=userInfo.Id %>">编辑</a> </td>
</tr>
<%} %>
</table>
<hr />
</div>
</form>
</body>
</html>
UserInfoList.aspx.cs
1.定义公共属性,以便子类访问
2.调用业务层的方法
using CZBK.ItcastProject.Model;
using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.UI;
using System.Web.UI.WebControls; namespace CZBK.ItcastProject.WebApp.aspx_Demo
{
public partial class UserInfoList : System.Web.UI.Page
{
public string StrHtml { get; set; }
public List<UserInfo> UserList { get; set; } /// <summary>
/// 页面加载完成以后。Load事件 Form_Load
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
protected void Page_Load(object sender, EventArgs e)
{
BLL.UserInfoService UserInfoService = new BLL.UserInfoService();
List<UserInfo> list = UserInfoService.GetList();
UserList = list;
}
}
}
5.删除数据
采用一般处理程序,因为删除不需要展示复杂的页面,这里用一般处理程序比aspx方便。
前台的删除代码
<td><a href="Delete.ashx?id=<%=userInfo.Id %>" class="deletes">删除</a></td>
Delete.ashx
using System;
using System.Collections.Generic;
using System.Linq;
using System.Web; namespace CZBK.ItcastProject.WebApp.aspx_Demo
{
/// <summary>
/// Delete 的摘要说明
/// </summary>
public class Delete : IHttpHandler
{
public void ProcessRequest(HttpContext context)
{
context.Response.ContentType = "text/plain";
BLL.UserInfoService UserInfoService = CZBK.ItcastProject.Common.CacheControl.Get<BLL.UserInfoService>();
int id;
if(int.TryParse(context.Request.QueryString["id"],out id))
{
if (UserInfoService.DeleteUserInfo(id))
{
context.Response.Redirect("UserInfoList.aspx");
}
else
{
context.Response.Redirect("Error.html");
}
}
else
{
context.Response.Redirect("Error.html");
}
} public bool IsReusable
{
get
{
return false;
}
}
}
}
6.添加数据
1. runat="server" 服务端控件! 会被.netframework解析成客户端的HTML代码返回给浏览器!但是会自动生成一个隐藏域,name="__ViewState"!这个ViewState用于保持状态连接,存储相关数据!
***IsPostBack:是根据__VIEWSTATE隐藏域进行判断的!
***如果不添加runat="server",则不会自动生成这个隐藏域,name="__ViewState"
2.aspx页面可以接受Get请求或者Post请求!注意:无论是Get请求还是Post请求,都会访问aspx.cs类中的Page_Load方法!!
3.aspx页面区分Get和Post请求:
a.在form表单中添加一个隐藏域,判断隐藏域的值;aspx.cs类中的Page_load方法中判断隐藏域的值,如果有值说明表单提交,是Post请求,否则为Get请求
<%@ Page Language="C#" AutoEventWireup="true" CodeBehind="AddUserInfo.aspx.cs"
Inherits="CZBK.ItcastProject.WebApp.aspx_Demo.AddUserInfo" %> <!DOCTYPE html>
<html xmlns="http://www.w3.org/1999/xhtml">
<head runat="server">
<meta http-equiv="Content-Type" content="text/html; charset=utf-8"/>
<title></title>
</head>
<body>
<form id="form1" method="post" action="AddUserInfo.aspx" >
<div>
用户名:<input type="text" name="txtName" /><br />
密码:<input type="password" name="txtPwd" /><br />
邮箱:<input type="text" name="txtMail" /><br />
<input type="hidden" name="isPostBack" value="aaa" /><!--隐藏域的值用于判断Post请求-->
<input type="submit" value="添加用户" />
</div>
</form>
</body>
</html>
using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.UI;
using System.Web.UI.WebControls;
using CZBK.ItcastProject; namespace CZBK.ItcastProject.WebApp.aspx_Demo
{
public partial class AddUserInfo : System.Web.UI.Page
{
BLL.UserInfoService UserInfoService = new BLL.UserInfoService();
protected void Page_Load(object sender, EventArgs e)
{
//判断 Get,Post请求
//如果隐藏域的值不为空,表示用户单击了提交按钮发出了POST请求
if(!string.IsNullOrEmpty(Request.Form["isPostBack"]))
{
//post请求
AddUserInfo_Method();
}
else
{
//get请求
}
} private void AddUserInfo_Method()
{
Model.UserInfo userinfo = new Model.UserInfo();
userinfo.UserName = Request.Form["txtName"];
userinfo.UserPass = Request.Form["txtPwd"];
userinfo.Email = Request.Form["txtMail"];
userinfo.RegTime = DateTime.Now;
if (UserInfoService.AddUserInfo(userinfo))
{
Response.Redirect("UserInfoList.aspx");
}
else
{
Response.Redirect("../Error.html");
}
}
}
}
b.使用服务端的 form表单,runat="server"!可以用IsPostBack来判断是否为Post请求还是Get请求!!!
<%@ Page Language="C#" AutoEventWireup="true" CodeBehind="AddUserInfo.aspx.cs"
Inherits="CZBK.ItcastProject.WebApp.aspx_Demo.AddUserInfo" %> <!DOCTYPE html>
<html xmlns="http://www.w3.org/1999/xhtml">
<head runat="server">
<meta http-equiv="Content-Type" content="text/html; charset=utf-8"/>
<title></title>
</head>
<body>
<form id="form1" runat="server" >
<div>
用户名:<input type="text" name="txtName" /><br />
密码:<input type="password" name="txtPwd" /><br />
邮箱:<input type="text" name="txtMail" /><br />
<input type="hidden" name="isPostBack" value="aaa" /><!--隐藏域的值用于判断Post请求-->
<input type="submit" value="添加用户" />
</div>
</form>
</body>
</html>
using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.UI;
using System.Web.UI.WebControls;
using CZBK.ItcastProject; namespace CZBK.ItcastProject.WebApp.aspx_Demo
{
public partial class AddUserInfo : System.Web.UI.Page
{
BLL.UserInfoService UserInfoService = new BLL.UserInfoService();
protected void Page_Load(object sender, EventArgs e)
{
//判断 Get,Post请求
//IsPostBack:如果是POST请求该属性的值为true,如果是GET请求该属性的值为false. //IsPostBack:是根据__VIEWSTATE隐藏域进行判断的,如果是POST请求那么该隐藏域的值会提交到服务端,
//那么IsPostBack属性也就为true.
//如果将form标签的runat="server"去掉,那么就不能用该属性进行判断是POST请求还是GET请求。
//因为去掉form标签的runat="server",那么就不会再产生 __VIEWSTATE隐藏域了。
if(IsPostBack)
{
AddUserInfo_Method();
}
} private void AddUserInfo_Method()
{
Model.UserInfo userinfo = new Model.UserInfo();
userinfo.UserName = Request.Form["txtName"];
userinfo.UserPass = Request.Form["txtPwd"];
userinfo.Email = Request.Form["txtMail"];
userinfo.RegTime = DateTime.Now;
if (UserInfoService.AddUserInfo(userinfo))
{
Response.Redirect("UserInfoList.aspx");
}
else
{
Response.Redirect("../Error.html");
}
}
}
}
7.更新数据
<%@ Page Language="C#" AutoEventWireup="true" CodeBehind="EditUser.aspx.cs"
Inherits="CZBK.ItcastProject.WebApp.aspx_Demo.EditUser" %> <!DOCTYPE html> <html xmlns="http://www.w3.org/1999/xhtml">
<head runat="server">
<meta http-equiv="Content-Type" content="text/html; charset=utf-8"/>
<title></title>
</head>
<body>
<form id="form1" method="post" action="EditUser.aspx">
<div>
用户名:<input type="text" name="txtName" value="<%=EditUserInfo.UserName %>" /><br />
密码:<input type="text" name="txtPwd" value="<%=EditUserInfo.UserPass %>" /><br />
邮箱:<input type="text" name="txtMail" value="<%=EditUserInfo.Email %>" /><br />
<input type="hidden" name="txtId" value="<%=EditUserInfo.Id %>" />
<input type="hidden" name="txtRegTime" value="<%=EditUserInfo.RegTime %>" />
<input type="hidden" name="Ispostback" value="aaa" />
<input type="submit" value="编辑用户" />
</div>
</form>
</body>
</html>
using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.UI;
using System.Web.UI.WebControls;
using CZBK.ItcastProject; namespace CZBK.ItcastProject.WebApp.aspx_Demo
{
public partial class EditUser : System.Web.UI.Page
{
BLL.UserInfoService userInfoservice = Common.CacheControl.Get<BLL.UserInfoService>();
public Model.UserInfo EditUserInfo { get; set; }
protected void Page_Load(object sender, EventArgs e)
{
if (!string.IsNullOrEmpty(Request.Form["Ispostback"]))
{
EditMethod();//post update
}
else
{
GetUserInfoMethod();//get
}
}
private void GetUserInfoMethod()
{
int id;
if (int.TryParse(Request.QueryString["id"], out id))
{
Model.UserInfo userinfo = userInfoservice.GetDeail(id);
if (userinfo != null)
{
EditUserInfo = userinfo;
}
else
Response.Redirect("../Error.html");
}
}
private void EditMethod()
{
Model.UserInfo userinfo = new Model.UserInfo();
userinfo.UserName = Request.Form["txtName"];
userinfo.UserPass = Request.Form["txtPwd"];
userinfo.Email = Request.Form["txtMail"];
userinfo.Id = Convert.ToInt32(Request.Form["txtId"]);
userinfo.RegTime = DateTime.Now;
if (userInfoservice.UpdateUserInfo(userinfo))
{
Response.Redirect("UserInfoList.aspx");
}
else
Response.Redirect("../Error.html");
}
}
}
asp.net 6.aspx页面的更多相关文章
- 老古董---ASP.NET中aspx页面runat="server"
自从 mvc3 被广泛的推进生产环境后,这个runat="server" 慢慢被人遗忘了... asp.net 的 webForm 基于控件的 html 渲染过程是否还记得呢?是 ...
- HTML控件ID和NAME属性的区别,以及如何在asp.net页面的.CS文件中获得.ASPX页面中HTML控件的值
在html中:name指的是用户名称,ID指的是用户注册是系统自动分配给用户的一个序列号. name是用来提交数据的,提供给表单用,可以重复: id则针对文档操作时候用,不能重复.如:document ...
- ASP.NET用户控件操作ASPX页面
定义一个不含数据的事件处理方法 用户控件 public event EventHandler Click; protected void Button1_Click(object sender, Ev ...
- ASP.NETMVC自定义错误页面真的简单吗?
Note:文章前半部分翻译自 http://benfoster.io/blog/aspnet-mvc-custom-error-pages ,着急的可直接看总结~ 如果你在设置asp.net mvc自 ...
- aspx页面调用发送邮件验证码(结合前两篇)
<%@ Page Language="C#" AutoEventWireup="true" CodeFile="Default3.aspx.cs ...
- Jquery Ajax调用aspx页面方法
Jquery Ajax调用aspx页面方法 在asp.net webform开发中,用jQuery ajax传值一般有几种玩法 1)普通玩法:通过一般处理程序ashx进行处理: 2)高级玩法:通过as ...
- 转:jquery向普通aspx页面发送ajax请求
本文将介绍在ASP.NET中如何方便使用Ajax,第一种当然是使用jQuery的ajax,功能强大而且操作简单方便,第二种是使用.NET封装好的ScriptManager. $.ajax向普通页面发送 ...
- Asp.Net中动态页面转静态页面
关于在Asp.Net中动态页面转静态页面的方法网上比较多.结合实际的需求,我在网上找了一些源代码,并作修改.现在把修改后的代码以及说明写一下. 一个是一个页面转换的类,该类通过静态函数Changfil ...
- HTML控件ID和NAME属性及在CS页面获得.ASPX页面中HTML控件的值
<转载>来自网络 一.ID是在客户端脚本里用!NAME是用于获取提交表单的某表单域信息,在form里面,如果不指定Name的话,就不会发送到服务器端,所以有name属性的控件,必须指定na ...
随机推荐
- ARP 之 发送请求arp_solicit
概述 arp_solicit用来发送ARP请求,首先会根据ARP_ANNOUNCE参数来选取源地址,然后判断是否达到内核发送次数上限,未达到则调用内核arp_send_dst函数发送,如果达到上限,则 ...
- ECharts3D地图(详细示例——附有具体注释)
3D地图图表效果如下: 具体代码如下: <!DOCTYPE html><html><head> <meta charset="UTF-8" ...
- YOLO: You Only Look Once论文阅读摘要
论文链接: https://arxiv.org/pdf/1506.02640.pdf 代码下载: https://github.com/gliese581gg/YOLO_tensorflow Abst ...
- 前端知识扫盲-VUE知识篇一(VUE核心知识)
最近对整个前端的知识做了一次复盘,总结了一些知识点,分享给大家有助于加深印象. 想要更加理解透彻的同学,还需要大家自己去查阅资料或者翻看源码.后面会陆续的更新一些相关注知识点的文章. 文章只提出问题, ...
- LC 926. Flip String to Monotone Increasing
A string of '0's and '1's is monotone increasing if it consists of some number of '0's (possibly 0), ...
- ubuntu更换源的方法
1.查看ubuntu版本的方法: 使用命令 sudo lsb_release -a 输出如下: root@localhost:/etc/apt# sudo lsb_release -aNo LSB m ...
- 使用Pull解析器生成XML文件
有些时候,我们需要生成一个XML文件,生成XML文件的方法有很多,如:可以只使用一个StringBuilder组拼XML内容,然后把内容写入到文件中:或者使用DOM API生成XML文件,或者也可以使 ...
- [Python]使用pytest进行单元测试
安装pytest pipenv install pytest 验证安装的版本: pytest --version This , imported /site-packages/pytest.py 接下 ...
- 小D课堂 - 新版本微服务springcloud+Docker教程_3-05 服务注册和发现Eureka Server搭建实战
笔记 5.服务注册和发现Eureka Server搭建实战 简介:使用IDEA搭建Eureka服务中心Server端并启动,项目基本骨架介绍 官方文档:http://clou ...
- Django Model模型
Model简介 模型准确且唯一的描述了数据.它包含您储存的数据的重要字段和行为.一般来说,每一个模型都映射一张数据库表. 每个模型都是一个 Python 的类,这些类继承 django.db.mode ...