一、注册
1、日期
(1)年月日用三DropDownList个,分别循环写入数字

代码写在后台

        Page_Load中的代码

if (IsPostBack == false)
{

       //年绑定数据
for (int i = DateTime.Now.Year; i >= ; i--)
{
ListItem li = new ListItem(i.ToString());
DropDownList5.Items.Add(li);
}
//月绑定数据
for (int i = ; i <= ; i++)
{
ListItem li = new ListItem(i.ToString());
DropDownList6.Items.Add(li);
}
//日绑定数据
rizi();
}

//年改变事件
DropDownList5.SelectedIndexChanged += DropDownList5_SelectedIndexChanged;
//月改变事件
DropDownList6.SelectedIndexChanged += DropDownList6_SelectedIndexChanged;

//日绑定数据函数
private void rizi()
{
int m = Convert.ToInt32(DropDownList6.SelectedValue);
int mm = Convert.ToInt32(DropDownList5.SelectedValue);
int rq = new panriqi().riqi(m, mm);
for (int i = ; i <= rq; i++)
{
ListItem li = new ListItem(i.ToString());
DropDownList7.Items.Add(li);
}
}
//年改变事件
void DropDownList5_SelectedIndexChanged(object sender, EventArgs e)
{
rizi();
}
//月改变事件
void DropDownList6_SelectedIndexChanged(object sender, EventArgs e)
{
rizi();
}

调用的类

public int riqi(int m,int mm) //传入年和月
{
int ri=;
if (m == || m == || m == || m == || m == || m == || m == )
{
ri = ;
}
else if (m == || m == || m == || m == )
{
ri = ;
}
else if (m == )
{ if (mm % == && mm % != || mm % == )
{
ri = ;
}
else
{
ri = ;
}
}
return ri;
}

(2)年月日取值

string s = DropDownList5.SelectedValue + "-" + DropDownList6.SelectedValue + "-" + DropDownList7.SelectedValue;
u.Birthday = Convert.ToDateTime(s);

2、水印 placeHolder
3、JS验证

//验证用户名
var duname = false;
document.getElementById("TextBox1").onblur = function () { if (document.getElementById("TextBox1").value == "") {
document.getElementById("Label1").innerText = "不能为空!";
}
else {
duname = true;
document.getElementById("Label1").innerText = "";
}
}
//注册按钮
document.getElementById("Button1").onclick = function () {
if (!duname || !dupwd || !dupwd2 || !dunicheng || !dup || !duyou || !duyz) {
alert("请确认是否全部填写正确!");
return false;//后面的代码不执行
}

4、三级联动
(1)修改一个属性:AutoPostBack

二、Repeater重复器
四个模板:
HeaderTemplate: 在加载开始执行一遍
ItemTemplate : 有多少条数据,执行多少遍
FooterTemplate :在加载最后执行一遍
AlternatingItemTemplate : 交替项模板
1、用table展示数据库中的数据

<asp:Repeater ID="Repeater1" runat="server">
<HeaderTemplate>//头模板
<table id="tb1">
//标题
<tr id="tr_head">
<td>用户名</td>
<td>密 码</td>
<td>昵称</td>
<td>性别</td>
<td>出生日期</td>
<td>年龄</td>
<td>电话</td>
<td>邮箱</td>
<td>民族</td>
<td>地区</td>
</tr>
</HeaderTemplate>
<ItemTemplate>//项模板
<tr class="tr_item" style="<%#Eval("red") %>">//red标红
<td><%#Eval("UserName") %></td>
<td><%#Eval("PassWord") %></td>
<td><%#Eval("NickName") %></td>
<td><%#Eval("sexstr ") %></td>
<td><%#Eval("bir") %></td>
<td><%#Eval("Age") %></td>
<td><%#Eval("Phone") %></td>
<td><%#Eval("Email") %></td>
<td><%#Eval("nationstr") %></td>
<td><%#Eval("Areastr") %></td>
</tr>
</ItemTemplate>
<FooterTemplate>//尾模板
</table>
</FooterTemplate>
</asp:Repeater>

2、属性扩展在实体类中
3、标红(实体类中属性扩展)

//性别为女标红
public string red
{
get
{
if(!_Sex)
{
return "background-color: red;";
}
else
{
return "";
} } }

4、光棒效果(JS)

window.onload = function () {
var oItems = document.getElementsByClassName("tr_item");
for (var i = ; i < oItems.length; i++) {
var oldColor = "";
oItems[i].onmouseover = function () {
//记录修改前的颜色
oldColor = this.style.backgroundColor;
this.style.backgroundColor = "yellow"; }; 
oItems[i].onmouseout = function ()
{ this.style.backgroundColor = oldColor; }; }

webform注册和Repeater的更多相关文章

  1. WebForm控件Repeater

    我们会发现用拼接字符串来显示一个查询非常的麻烦,有一个控件Repeater帮助你,省去写Foreach LinQ to SQL类 函数类: using System; using System.Col ...

  2. Webform——注册验证

    服务器控件和客户端控件的交替使用,主要还是获取到各个控件的值,直接用C#或Js判断是否符合条件就可以. 这里是以服务器控件为例子,至于客户端控件则需要写JS代码 .UserBF public clas ...

  3. Webform(Repeater控件)

    一.Repeater控件 有五大模板 ItemTemplate :有多少条数据,执行多少遍        AlternatingItemTemplate : 对交替数据项进行格式设置       Se ...

  4. Webform——Repeater多表联合显示

    对于一个表里,通过外键连接如何显示另一个表的数据,前Winform里可以用封装类来实现. 对于Webform,可以用封装类,也可以用Repeater的ItemDataBound事件(//在项被绑定数据 ...

  5. WebForm 【Repeater】展示数据

       在 Webform 数据展示中      界面层  : HTLM 业务逻辑层 :只能用 C#  Repeater    重复器  能够用来循环展示数据 具有5种模板  HeaderTemplat ...

  6. webform之Repeater控件

    一.Repeater控件 数据循环编辑 1.repeater包括五大模板: (1)HeaderTemplate:标题模板,对开头进行编辑,只执行一次 (2)FooterTemplate:页尾结束模板, ...

  7. webform中Repeater的Command用法、Repeater的替代方法

    Command: 在Repeater控件循环执行过程中,可以给每一项的某个按钮或其他控件设置CommandName.CommandArgument属性,用于在后台代码中获取单项 数据进行调用.   需 ...

  8. Webform(七)——内置对象(Session、Application)和Repeater的Command操作

    内置对象:用于页面之间的数据交互 为什么要使用这么内置对象?因为HTTP的无状态性. 一.内置对象 (一)Session 跟Cookies一样用来存储用户数据 1.Session.Cookies对比 ...

  9. Webform(五)——内置对象(Response、Request)和Repeater中的数据增删改

    一.内置对象 (一)Response对象 1.简介:response 对象在ASP中负责将信息传递给用户.Response对象用于动态响应客户端请求,并将动态生成的响应结果返回到客户端浏览器中,使用R ...

随机推荐

  1. decimal(a,b)

    decimal(a,b)a指定指定小数点左边和右边可以存储的十进制数字的最大个数,最大精度38.b指定小数点右边可以存储的十进制数字的最大个数.小数位数必须是从 0 到 a之间的值.默认小数位数是 0 ...

  2. Ubuntu中开启MySQL远程访问功能,并将另一个数据库服务器中的数据迁移到新的服务器中

    一.开启MyS远程访问功能 1.进入服务器输入netstat -an | grep 3306确认3306是否对外开放,MySQL默认状态下是不对外开放访问功能的.输入以上命令之后如果端口没有被开放就会 ...

  3. unity, 播放循环背景音乐注意事项

    循环背景音乐用wav格式,不要用mp3. 参考:http://answers.unity3d.com/questions/343057/how-do-i-make-unity-seamlessly-l ...

  4. MSSQL 创建自定义异常

    创建时,必须先创建英文的,否则会报错:必须添加此消息的 us_english 版本后,才能添加 '简体中文' 版本. EXEC sp_addmessage 50001, 15, 'option wro ...

  5. Spring中的ApplicationContext事件机制

    ApplicationContext的事件机制是观察者设计模式的实现,通过ApplicationEvent类和ApplicationListerner接口来实现. 1. 创建EmailEvent pu ...

  6. ef执行记录原生态代码方法。

    select e; var f = (System.Data.Objects.ObjectQuery<SimpleEntry>)final; var s = f.ToTraceString ...

  7. 【python】and和or的用法

    python 中的and从左到右计算表达式,若所有值均为真,则返回最后一个值,若存在假,返回第一个假值. or也是从左到有计算表达式,返回第一个为真的值. IDLE 1.2.4>>> ...

  8. Django缓存使用方法

    Django缓存分为Session和Cookie:Session为放在服务器端的缓存:Cookie为放在客户端(浏览器)的缓存. Session一般用来保存登录会话:Cookie一般用来保存一些个性化 ...

  9. 黄聪:MySQL 按指定字段自定义列表排序

    问题描述 大家都知道, MySQL 中按某字段升序排列的 SQL 为 (以 id 为例, 下同): SELECT * FROM `MyTable` , , , ) ORDER BY `id` ASC ...

  10. c# Wndproc的使用方法

    protected override void WndProc(ref Message m) { const int WM_SYSCOMMAND = 0x0112; const int SC_CLOS ...