zoukankan      html  css  js  c++  java
  • Web学习内容回顾整理

    20151213~20151227Web学习内容回顾整理

    C/S: Client客户端程序

    B/S: Brower浏览器程序

    .net服务器软件:IIS

    Java:TomCat

    Php:阿帕奇

    一、页面传值

    二、下拉列表:DropDownList

    三、列表框: ListBox

    四、单选框:RadioButton 复选框:CheckBox

         4.1CheckBoxList 控件:去重显示 ;复选框多选时可点击查询查出结果

    五、Repeater

    六、分页

    七、关键字查询变色

    八、流水号

    九、验证控件

    十、上传文件

    1.TextBox:用户输入文本框  属性:TextMode  单行文本框SingleLine  多行文本框MultiLine  密码框Password
    2.显示文字:lable会生成Span标签  
              literall将文字原封不动的打到页面
    3.按钮:Button普通按钮
           ImageButton图片按钮 ,只能从根目录下照图片
           LinkButton超链接按钮,属性PostBackUrl
    4.Image:图片工具  
      HyperLink:超链接工具,属性NavigateUrl跳向的页面
    跳转页面:
            //方式一,重定向页面,会直接换掉浏览器中的Url,可以跳转到任何页面
            Response.Redirect("Default.aspx?uid=123&pwd=123");
            //方式二,重新请求页面直接显示在当前页面,跳转根目录下的页面
            Server.Transfer("Default.aspx");
    页面传值:
    1.QueryString:Form表单的提交方式        
        传值页面传值:Response.Redirect("Test.aspx?uid=123&pwd=123");
        接收页面取值:Request["uid"].ToString();
    
    2.Session
        特点:默认过期时间是20分钟,存储在服务器的,每人一个,可以存储任何东西,安全,占资源。
        用法:传值页面传值:Session["key"]="aa";
             接收页面取值:Session["key"];
    
    3.Cookie
        特点:默认永不过期,存储在客户端的,只能存放字符串。
        用法:传值页面传值:    
    //1.造Cookie对象 HttpCookie aa = new HttpCookie("uid"); //2.给该Cookie一个值 aa.Value = "aa"; //3.写入客户端 Response.AppendCookie(aa); 接收页面取值:Request.Cookies["uid"].Value.ToString(); 4.Application 特点:存储在服务器,只存储一份 用法:传值页面传值:Application["uid"] = "aa"; 接收页面取值:Application["uid"].ToString();

    下拉列表:DropDownList

    1、绑定数据方法一:
            testDataContext context = new testDataContext();
            DropDownList1.DataSource = context.Nation;//指定数据源
            DropDownList1.DataValueField = "Code";
            DropDownList1.DataTextField = "Name";
            DropDownList1.DataBind();//绑定数据
    
       绑定数据方法二:造一个ListItem项
            ListItem item = new ListItem();
            item.Text = "中国";
            item.Value = "0001";           
    
            ListItem item1 = new ListItem();
            item1.Text = "韩国";
            item1.Value = "0002";
    
            DropDownList1.Items.Add(item);
            DropDownList1.Items.Add(item1);
        绑定数据方法三:
            点击DropDownList右边的小箭头,选择数据源
         
    2、取选中项的值
            将DropDownList属性中的AutoPostBack设置为true
             protected void DropDownList1_SelectedIndexChanged(object sender, EventArgs e)
             {
                 Label1.Text = DropDownList1.SelectedValue.ToString();
             }
             if (!IsPostBack){}//避免重新绑定数据
    3、设置哪一项选中
             方法一:
             DropDownList1.SelectedIndex = 2;
             方法二:
             foreach( ListItem item in DropDownList1.Items )
                {
                    if (item.Value == "n002")
                    {
                        item.Selected = true;
                    }
                }
    private testDataContext context = new testDataContext();
        protected void Page_Load(object sender, EventArgs e)
        {
            //页面加载时填充上省市区
            if(!IsPostBack)
            {
                FillSheng();
                FillShi();
                FillQu();
            }
        }
        //先写三个方法,第一个填充省,第二个填充市,第三个填充区
        public void FillSheng()
        {
            dropsheng.DataSource = context.ChinaStates.Where(p =>p.ParentAreaCode == "0001");
            dropsheng.DataTextField = "AreaName";
            dropsheng.DataValueField = "AreaCode";
    
            dropsheng.DataBind();
        }
        public void FillShi()
        { 
            //先找出选中的省的代号
            string sheng = dropsheng.SelectedValue.ToString();
            dropshi.DataSource = context.ChinaStates.Where(p => p.ParentAreaCode == sheng);
            dropshi.DataTextField = "AreaName";
            dropshi.DataValueField = "AreaCode";
    
            dropshi.DataBind();
        }
        public void FillQu()
        {
            string shi = dropshi.SelectedValue.ToString();
            dropqu.DataSource = context.ChinaStates.Where(p => p.ParentAreaCode == shi);
            dropqu.DataTextField = "AreaName";
            dropqu.DataValueField = "AreaCode";
    
            dropqu.DataBind();
        }
        //事件,点击省时,市也变化,点击市时,区也变化
        //1、将DropDownList属性中的AutoPostBack设置为true
        //2、省变化的时候填充市,市变化的时候填充区
        protected void dropsheng_SelectedIndexChanged(object sender, EventArgs e)
        {
            FillShi();
        }
        protected void dropshi_SelectedIndexChanged(object sender, EventArgs e)
        {
            FillQu();
        }
    练习:三级联动省份表

    实现效果:

    列表框: ListBox

     1、 绑定数据 方法一:
            testDataContext context = new testDataContext();
            ListBox1.DataSource = context.Nation;
            ListBox1.DataValueField = "Code";
            ListBox1.DataTextField = "Name";
            ListBox1.DataBind();
         绑定数据 方法二:
            ListItem item = new ListItem();
            item.Value = "0001";
            item.Text = "中国";
            ListBox1.Items.Add(item);
         绑定数据 方法三:
            点击ListBox右边的小箭头,选择数据源
    
     2、 取选中的值:
            ListBox属性中SelectionMode设置为Single是单选,Multiple是多选
            单选:
                Label1.Text = ListBox1.SelectedValue.ToString();
            多选:
                Label1.Text = "";//清空
                foreach (ListItem item in ListBox1.Items)
                {
                    if (item.Selected)
                    {
                        Label1.Text += item.Value;
                    }
                }
    3、设置哪一项选中
            单选:
                ListBox1.SelectedIndex = 0;
            多选:
                foreach (ListItem item in ListBox1.Items)
                {
                    if (item.Text =="汉族"||item.Text == "满族")
                    {
                        item.Selected = true;
                    }
                }
    protected void Page_Load(object sender, EventArgs e)
        {
            if (!IsPostBack)
            {
                testDataContext context = new testDataContext();
    
                ListBox1.DataSource = context.Nation;
                ListBox1.DataTextField = "Name";
                ListBox1.DataValueField = "Code";
                ListBox1.DataBind();
            }
        }
        protected void Button1_Click(object sender, EventArgs e)
        {
            //把选中的listbox1的数据放到listbox2
            //先找选中项
            foreach( ListItem item in ListBox1.Items )
            {
                if(item.Selected)
                {
                    if (!ListBox2.Items.Contains(item))//判断listbox2中有没有1里面选中的项,避免重复添加
                    {
                        ListBox2.Items.Add(item);
                    }
                }
            }
        }
        protected void Button2_Click(object sender, EventArgs e)
        {
            //把listbox1中的所有数据都放到listbox2中
            foreach (ListItem item in ListBox1.Items)
            {
                if (!ListBox2.Items.Contains(item))//判断listbox2中有没有1里面选中的项,避免重复添加
                {
                    ListBox2.Items.Add(item);
                }
            }
        }
    列表框练习

     实现效果:

    单选框:Radiobutton 单选按钮列表:RadioButtonList

    单选框:RadioButton
    RadioButton中有个属性GroupName,当单选时,必须把各个选项的组名设成同一个
    查看按钮是否选中:bool sex = RadioButton1.Checked;
                    Label1.Text = sex.ToString();
    单选按钮列表:RadioButtonList 属性:RepeatDirection:横向或纵向 绑定数据: TextDataContext context
    = new TextDataContext(); RadioButtonList1.DataSource = context.Nation; RadioButtonList1.DataTextField = "Name"; RadioButtonList1.DataValueField = "Code"; RadioButtonList1.DataBind(); 取选中项的值: Label1.Text =RadioButtonList1.SelectedValue.ToString(); 设置哪一项被选中: RadioButtonList1.SelectedIndex = 2;

    复选框:CheckBox 复选框列表:CheckBoxList

    复选框:CheckBox
        看一下该按钮是否选中:checkbox1.Checked;
        其余和单选框一样
    
    复选框列表:CheckBoxList
        属性RepeatDirection:横向Horizontal或纵向Vertical
        绑定数据:
            CheckBoxList1.DataSource = context.Nation;
            CheckBoxList1.DataTextField = "Name";
            CheckBoxList1.DataValueField = "Code";
            CheckBoxList1.DataBind();
        取选中项的值:
            Label1.Text = "";//清空
            foreach( ListItem item in CheckBoxList1.Items)
            {
                if (item.Selected)
                {
                    Label1.Text += item.Text;
                }
            }
        设置哪一项被选中:
            单项选中:
                CheckBoxList1.SelectedIndex = 2;
            多项选中:
                foreach (ListItem item in CheckBoxList1.Items)
                {
                    if (item.Text == "汉族" || item.Text == "满族")
                    {
                        item.Selected = true;
                    }
                }
    如果代码没有执行,很有可能是AutoPostBack没有设置为Ture
    protected void Page_Load(object sender, EventArgs e)
        {
            if (!IsPostBack)
            {
                TextDataContext context = new TextDataContext();
                CheckBoxList1.DataSource = context.Nation;
                CheckBoxList1.DataTextField = "Name";
                CheckBoxList1.DataValueField = "Code";
                CheckBoxList1.DataBind();
            }
        }
        protected void CheckBox1_CheckedChanged(object sender, EventArgs e)
        {
            //设置点击全选和取消全选
            foreach( ListItem item in CheckBoxList1.Items )
            {
                item.Selected = CheckBox1.Checked;
            }
        }
        protected void Button1_Click(object sender, EventArgs e)
        {
            //取值
            string zhi = "";
            foreach( ListItem item in CheckBoxList1.Items )
            {
                if(item.Selected)
                {
                    zhi += item.Value.ToString()+",";//用,分割
                }
            }
            //去掉最后多余的逗号
            zhi = zhi.Substring(0, zhi.Length - 1);
            //拆分字符串,把选中的每一项都弹出一个窗体
            string[] codes;
            codes = zhi.Split(',');
            //造js代码
            string js = "<script type='text/javascript'>";
            for (int i = 0; i < codes.Length; i++)
            {
                js += "alert('"+codes[i]+"');";
            }
            js += "</script>";
            Literal1.Text = js;
                //弹出一个窗体,显示选中的值,借助一个工具Literall,在Literall中写js代码
                //Literal1.Text = "<script type='text/javascript'>alert('" + zhi + "')</script>";
    
        }
    练习:全选

    实现效果:

    Repeater:

     往HTML里面嵌入c#代码,格式:<%#Eval("") %>,
        #代表绑定数据,Eval()括号里面写列名属性名
    Repeater:
    
        用法:
            1、绑定数据源:
                    if(!IsPostBack)
                    {
                        TextDataContext context = new TextDataContext();
                        Repeater1.DataSource = context.Info;
                        Repeater1.DataBind();
                    }
             2、造模板:
                头模板:HeaderTemplate:只出现一次,一般是标题行
                脚模板:FooterTemplate:只出现一次
                项模板:ItemTemplate:根据数据源中数据的多少生成。
                                绑定数据:
                            1.Eval("Code"):绑定显示某一个字段
                            2.调用函数来显示数据
                            3.绑定主表中的字段:Nation1.Name
                            4.格式化显示数据:Eval("Birthday","{0:yyyy年MM月dd日}")
    
              3、如何出现交替项
                    交替模板:AlternatingItemTemplate:用来交替显示数据,一般只需要改变样式。
    
    用Repeater根据数据库中的数据做菜单:
            1、绑定数据:
                Repeater2.DataSource = context.Nation;
                Repeater2.DataBind();
            2、造模板:
                头模板:<HeaderTemplate><u id="menu"></HeaderTemplate>
                项模板:<ItemTemplate><li class="cd" bs="<%#Eval("Code") %>"><%#Eval("Name") %></li></ItemTemplate>
                脚模板:<FooterTemplate></u></FooterTemplate>
            3、样式表:
                  <style type="text/css">
                    * {
                        margin: 0px auto;
                        padding: 0px;
                    }
                    #menu {
                        list-style:none;
                    }
                    .cd {
                        float:left;
                        100px;
                        height:30px;
                        background-color:#808080;
                        font-size:13px;
                        font-family:微软雅黑;
                        text-align:center;
                        line-height:30px;
                        vertical-align:middle;
                        color:#fff;
                        border-right:1px solid black;
                    }
                </style>
    
    改变表格中字体颜色:两种方式
    把性别显示成男女,民族显示成民族名称,生日格式化显示
        一:写函数,调用函数
        二:直接找到主表中的列

     练习:

    20151217:Web之Repeater使用:主页面

    20151217:Web之Repeater使用:添加

    20151217:Web之Repeater使用:修改

    20151217:Web之Repeater使用:删除

    复习:

    20151221:Web复习:登陆

    20151221:Web复习:主界面

    20151221:Web复习:添加

    20151221:Web复习:修改

    20151221:Web复习:删除

    分页

     1 <%@ Page Language="C#" AutoEventWireup="true" CodeFile="Default.aspx.cs" Inherits="_Default" %>
     2 
     3 <!DOCTYPE html>
     4 
     5 <html xmlns="http://www.w3.org/1999/xhtml">
     6 <head runat="server">
     7 <meta http-equiv="Content-Type" content="text/html; charset=utf-8"/>
     8     <title></title>
     9 </head>
    10 <body>
    11     <form id="form1" runat="server">
    12     <div>
    13         <h1>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; 汽车表分页</h1>
    14         <asp:Repeater ID="Repeater1" runat="server">
    15             <HeaderTemplate>
    16                 <table width="1000" border="0" cellspacing="1" cellpadding="1" bgcolor="#6600FF">
    17                   <tr>
    18                     <td width="120" height="30" align="center" valign="middle" bgcolor="#FFFFFF">代号</td>
    19                     <td width="120" align="center" valign="middle" bgcolor="#FFFFFF">名称</td>
    20                     <td width="120" align="center" valign="middle" bgcolor="#FFFFFF">系列</td>
    21                     <td width="120" align="center" valign="middle" bgcolor="#FFFFFF" >上市时间</td>
    22                     <td width="100" align="center" valign="middle" bgcolor="#FFFFFF">油耗</td>
    23                     <td width="100" align="center" valign="middle" bgcolor="#FFFFFF">功率</td>
    24                     <td width="100" align="center" valign="middle" bgcolor="#FFFFFF">排量</td>
    25                     <td width="100" align="center" valign="middle" bgcolor="#FFFFFF">价格</td>
    26                     <td width="100" align="center" valign="middle" bgcolor="#FFFFFF">图片</td>
    27                   </tr>
    28             </HeaderTemplate>
    29             <ItemTemplate>
    30                 <tr>
    31                     <td width="120" height="30" align="center" valign="middle" bgcolor="#FFFFFF"><%#Eval("Code") %></td>
    32                     <td width="120" align="center" valign="middle" bgcolor="#FFFFFF"><%#Eval("Name") %></td>
    33                     <td width="120" align="center" valign="middle" bgcolor="#FFFFFF"><%#Eval("Brand") %></td>
    34                     <td width="120" align="center" valign="middle" bgcolor="#FFFFFF" ><%#Eval("Time") %></td>
    35                     <td width="100" align="center" valign="middle" bgcolor="#FFFFFF"><%#Eval("Oil") %></td>
    36                     <td width="100" align="center" valign="middle" bgcolor="#FFFFFF"><%#Eval("Powers") %></td>
    37                     <td width="100" align="center" valign="middle" bgcolor="#FFFFFF"><%#Eval("Exhaust") %></td>
    38                     <td width="100" align="center" valign="middle" bgcolor="#FFFFFF"><%#Eval("Price") %></td>
    39                     <td width="100" align="center" valign="middle" bgcolor="#FFFFFF"><%#Eval("Pic") %></td>
    40                   </tr>
    41             </ItemTemplate>
    42             <FooterTemplate>
    43                 </table>
    44             </FooterTemplate>
    45 
    46         </asp:Repeater>
    47     
    48         <asp:Literal ID="Literal1" runat="server"></asp:Literal>
    49     
    50         <br />
    51         <asp:Button ID="Button1" runat="server" OnClick="Button1_Click" Text="上一页" />
    52 &nbsp;&nbsp;
    53         <asp:Button ID="Button2" runat="server" OnClick="Button2_Click" Text="下一页" />
    54 &nbsp;&nbsp;&nbsp;
    55         <asp:Label ID="Label2" runat="server" Text="跳转到"></asp:Label>
    56         <asp:TextBox ID="TextBox1" runat="server" Width="36px"></asp:TextBox>
    57         <asp:Label ID="Label3" runat="server" Text="页"></asp:Label>
    58 &nbsp;<asp:Button ID="Button3" runat="server" OnClick="Button3_Click" Text="跳转" />
    59 &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;
    60         <asp:Label ID="Label1" runat="server" Text="Label"></asp:Label>
    61         <br />
    62     
    63     </div>
    64     </form>
    65 </body>
    66 </html>
    前台
     1 public partial class _Default : System.Web.UI.Page
     2 {
     3     private TextDataContext context = new TextDataContext();
     4     protected void Page_Load(object sender, EventArgs e)
     5     {
     6         if (!IsPostBack)
     7         {
     8             Session["ys"] = 1;
     9             //Skip()跳过多少条,Take()取多少条数据
    10             TiaoZhuan(1);
    11         }
    12         Literal1.Text = "";
    13     }
    14     protected void Button1_Click(object sender, EventArgs e)
    15     {
    16         //上一页
    17         int ys = Convert.ToInt32(Session["ys"]);//取出session的值
    18 
    19         if (ys > 1)//判断当前页数大于1或等于1
    20         {
    21             ys = ys - 1;
    22             Session["ys"] = ys;
    23             TiaoZhuan(ys);
    24         }
    25         else
    26         {
    27             Literal1.Text = "<script type='text/javascript'>alert('当前已是第一页!')</script>";
    28         }
    29     }
    30     protected void Button2_Click(object sender, EventArgs e)
    31     {
    32         //下一页
    33         int ys = Convert.ToInt32(Session["ys"]);//取出session的值
    34 
    35         int zys = AllYS();
    36 
    37         if (ys < zys)//判断当前页数与总页数的关系
    38         {
    39             ys = ys + 1;
    40             Session["ys"] = ys;
    41             TiaoZhuan(ys);
    42         }
    43         else
    44         {
    45              Literal1.Text = "<script type='text/javascript'>alert('当前已是最后一页!')</script>";            
    46         }
    47     }
    48     //跳转到第几页
    49     public void TiaoZhuan(int ys)
    50     {
    51         int qu = (ys - 1) * 5;//跳过的条数
    52         Repeater1.DataSource = context.car.Skip(qu).Take(5);
    53         Repeater1.DataBind();
    54 
    55         int all = AllYS();
    56         Label1.Text = "当前第:"+ys+"页,总共:"+all+"";
    57     }
    58     //取总页数
    59     public int AllYS()
    60     {
    61         int all = context.car.Count();//总共多少条数据
    62         int zys;//总页数
    63         if (all % 5 == 0)
    64         {
    65             zys = all / 5;
    66         }
    67         else
    68         {
    69             zys = all / 5 + 1;
    70         }
    71         return zys;
    72     }
    73     protected void Button3_Click(object sender, EventArgs e)
    74     {
    75         int ys = 1;
    76         try
    77         {
    78              ys = Convert.ToInt32(TextBox1.Text);
    79         }
    80         catch(Exception)
    81         {
    82             Literal1.Text = "<script type='text/javascript'>alert('请输入数字!')</script>"; 
    83         }
    84         
    85         int all = AllYS(); 
    86         if (1 <= ys && ys <= all)
    87         {
    88             TiaoZhuan(ys);
    89             Session["ys"] = ys;
    90         }
    91         else
    92         {
    93             Literal1.Text = "<script type='text/javascript'>alert('超出范围!')</script>"; 
    94         }
    95     }
    96 }
    后台

    实现效果:

    关键字查询变色:

     1 <%@ Page Language="C#" AutoEventWireup="true" CodeFile="Default2.aspx.cs" Inherits="Default2" %>
     2 
     3 <!DOCTYPE html>
     4 
     5 <html xmlns="http://www.w3.org/1999/xhtml">
     6 <head runat="server">
     7 <meta http-equiv="Content-Type" content="text/html; charset=utf-8"/>
     8     <title></title>
     9 </head>
    10 <body>
    11     <form id="form1" runat="server">
    12     <div>
    13         <h1>汽车表</h1>
    14         <p>
    15             <asp:Label ID="Label2" runat="server" Text="汽车名称:"></asp:Label>
    16             <asp:TextBox ID="TextBox1" runat="server" Width="121px"></asp:TextBox>
    17 &nbsp;<asp:Button ID="Button1" runat="server" OnClick="Button1_Click" Text="查询" />
    18         </p>
    19         <asp:Repeater ID="Repeater1" runat="server">
    20             <HeaderTemplate>
    21                 <table width="1000" border="0" cellspacing="1" cellpadding="1" bgcolor="#6600FF">
    22                   <tr>
    23                     <td width="120" height="30" align="center" valign="middle" bgcolor="#FFFFFF">代号</td>
    24                     <td width="120" align="center" valign="middle" bgcolor="#FFFFFF">名称</td>
    25                     <td width="120" align="center" valign="middle" bgcolor="#FFFFFF">系列</td>
    26                     <td width="120" align="center" valign="middle" bgcolor="#FFFFFF" >上市时间</td>
    27                     <td width="100" align="center" valign="middle" bgcolor="#FFFFFF">油耗</td>
    28                     <td width="100" align="center" valign="middle" bgcolor="#FFFFFF">功率</td>
    29                     <td width="100" align="center" valign="middle" bgcolor="#FFFFFF">排量</td>
    30                     <td width="100" align="center" valign="middle" bgcolor="#FFFFFF">价格</td>
    31                     <td width="100" align="center" valign="middle" bgcolor="#FFFFFF">图片</td>
    32                   </tr>
    33             </HeaderTemplate>
    34             <ItemTemplate>
    35                 <tr>
    36                     <td width="120" height="30" align="center" valign="middle" bgcolor="#FFFFFF"><%#Eval("Code") %></td>
    37                     <td width="120" align="center" valign="middle" bgcolor="#FFFFFF"><%#Eval("Name") %></td>
    38                     <td width="120" align="center" valign="middle" bgcolor="#FFFFFF"><%#Eval("Brand") %></td>
    39                     <td width="120" align="center" valign="middle" bgcolor="#FFFFFF" ><%#Eval("Time") %></td>
    40                     <td width="100" align="center" valign="middle" bgcolor="#FFFFFF"><%#Eval("Oil") %></td>
    41                     <td width="100" align="center" valign="middle" bgcolor="#FFFFFF"><%#Eval("Powers") %></td>
    42                     <td width="100" align="center" valign="middle" bgcolor="#FFFFFF"><%#Eval("Exhaust") %></td>
    43                     <td width="100" align="center" valign="middle" bgcolor="#FFFFFF"><%#Eval("Price") %></td>
    44                     <td width="100" align="center" valign="middle" bgcolor="#FFFFFF"><%#Eval("Pic") %></td>
    45                   </tr>
    46             </ItemTemplate>
    47             <FooterTemplate>
    48                  </table>
    49             </FooterTemplate>
    50         </asp:Repeater>
    51     
    52     </div>
    53     </form>
    54 </body>
    55 </html>
    前台
     1 public partial class Default2 : System.Web.UI.Page
     2 {
     3     private TextDataContext context = new TextDataContext();
     4     protected void Page_Load(object sender, EventArgs e)
     5     {
     6         if (!IsPostBack)
     7         {
     8             Repeater1.DataSource = context.car;
     9             Repeater1.DataBind();
    10         }
    11     }
    12     protected void Button1_Click(object sender, EventArgs e)
    13     {
    14         //关键字查询变色
    15         string name = TextBox1.Text;
    16 
    17         if (name != "")
    18         {
    19             var query = context.car.Where(p => p.name.Contains(name));
    20             foreach (car data in query)
    21             {
    22                 //变成黄色
    23                 //data.name = data.name.Replace(name, "<mark>" + name + "</mark>");
    24                 //变成红色
    25                 data.name = data.name.Replace(name, "<span style='background-color:red'>" + name + "</span>");
    26             }
    27             Repeater1.DataSource = query;
    28             Repeater1.DataBind();
    29         }
    30         else
    31         {
    32             Repeater1.DataSource = context.car;
    33             Repeater1.DataBind();
    34         }
    35     }
    36 }
    后台

    实现效果:

    流水号:

     1 <%@ Page Language="C#" AutoEventWireup="true" CodeFile="liushuihao.aspx.cs" Inherits="liushuihao" %>
     2 
     3 <!DOCTYPE html>
     4 
     5 <html xmlns="http://www.w3.org/1999/xhtml">
     6 <head runat="server">
     7 <meta http-equiv="Content-Type" content="text/html; charset=utf-8"/>
     8     <title></title>
     9 </head>
    10 <body>
    11     <form id="form1" runat="server">
    12          <div>
    13              <h1>添加商品</h1>
    14         <p>
    15             <asp:Label ID="Label1" runat="server" Text="名称:"></asp:Label>
    16             <asp:TextBox ID="TextBox1" runat="server"></asp:TextBox>
    17         </p>
    18         <p>
    19             <asp:Label ID="Label2" runat="server" Text="价格:"></asp:Label>
    20             <asp:TextBox ID="TextBox2" runat="server"></asp:TextBox>
    21         </p>
    22         <p>
    23             <br />
    24             <asp:Button ID="Button1" runat="server" Text="添加" OnClick="Button1_Click" />
    25         &nbsp;&nbsp;&nbsp;&nbsp;
    26             <asp:Button ID="Button2" runat="server" Text="随机" OnClick="Button2_Click" />
    27         </p>
    28    
    29     
    30     </div>
    31     </form>
    32 </body>
    33 </html>
    前台
     1 public partial class liushuihao : System.Web.UI.Page
     2 {
     3     private TextDataContext context = new TextDataContext();
     4     protected void Page_Load(object sender, EventArgs e)
     5     {
     6 
     7     }
     8     protected void Button1_Click(object sender, EventArgs e)
     9     {
    10         string name = TextBox1.Text;
    11         double price = Convert.ToDouble(TextBox2.Text);
    12 
    13         string code = "";
    14         //看一下表里面有没有数据
    15         if (context.ShangPin.Count() == 0)//没有数据
    16         {
    17             code = DateTime.Now.ToString("yyyyMMdd") + "001";
    18         }
    19         else
    20         { 
    21             string max = context.ShangPin.Max(p=>p.Code);
    22             string max1 = max.Substring(8,3);//截取字符串
    23 
    24             string rq = max.Substring(0,8);
    25 
    26             if (rq == DateTime.Now.ToString("yyyyMMdd"))//判断是否是同一天
    27             {
    28 
    29                 int max2 = Convert.ToInt32(max1);
    30                 max2 = max2 + 1;
    31                 //拼接字符串
    32                 if (max2 < 10)
    33                 {
    34                     code = DateTime.Now.ToString("yyyyMMdd") + "00" + max2;
    35                 }
    36                 else if (max2 < 100)
    37                 {
    38                     code = DateTime.Now.ToString("yyyyMMdd") + "0" + max2;
    39                 }
    40                 else
    41                 {
    42                     code = DateTime.Now.ToString("yyyyMMdd") + max2;
    43                 }
    44             }
    45             else
    46             {
    47                 code = DateTime.Now.ToString("yyyyMMdd") + "001";
    48             }
    49         }
    50         //添加
    51         ShangPin data = new ShangPin();//造对象
    52         data.Code = code;
    53         data.Name = name;
    54         data.Price = price;
    55 
    56         context.ShangPin.InsertOnSubmit(data);
    57         context.SubmitChanges();
    58 
    59     }
    60     protected void Button2_Click(object sender, EventArgs e)
    61     {
    62         //随机
    63         string name = TextBox1.Text;
    64         double price = Convert.ToDouble(TextBox2.Text);
    65         //生成随机数
    66         Random rd = new Random();
    67 
    68         string code = DateTime.Now.ToString("yyyyMMddHHmmss")+rd.Next(1000);
    69         //添加
    70         ShangPin data = new ShangPin();//造对象
    71         data.Code = code;
    72         data.Name = name;
    73         data.Price = price;
    74 
    75         context.ShangPin.InsertOnSubmit(data);
    76         context.SubmitChanges();
    77     }
    78 }
    后台

    数据库查询显示:

    练习:审核

    20151223:Web:审核:注册

    20151223:Web:审核:登陆

    20151223:Web:审核:主页面

    20151223:Web:审核:审核和取消

    CheckBoxList 控件:去重显示 ;复选框多选时可点击查询查出结果

     1 <%@ Page Language="C#" AutoEventWireup="true" CodeFile="Main.aspx.cs" Inherits="Main" %>
     2 
     3 <!DOCTYPE html>
     4 
     5 <html xmlns="http://www.w3.org/1999/xhtml">
     6 <head runat="server">
     7 <meta http-equiv="Content-Type" content="text/html; charset=utf-8"/>
     8     <title></title>
     9 </head>
    10 <body>
    11     <form id="form1" runat="server">
    12     <div>
    13     
    14         <br />
    15         <br />
    16         <asp:Label ID="Label1" runat="server" Text="区域:"></asp:Label>
    17         <asp:CheckBox ID="CheckBox1" runat="server" AutoPostBack="True" OnCheckedChanged="CheckBox1_CheckedChanged" Text="全选" />
    18         <br />
    19         <asp:CheckBoxList ID="CheckBoxList1" runat="server" RepeatDirection="Horizontal">
    20         </asp:CheckBoxList>
    21         <br />
    22         <asp:Label ID="Label2" runat="server" Text="租赁类型:"></asp:Label>
    23         <asp:CheckBox ID="CheckBox2" runat="server" AutoPostBack="True" OnCheckedChanged="CheckBox2_CheckedChanged" Text="全选" />
    24         <br />
    25         <asp:CheckBoxList ID="CheckBoxList2" runat="server" RepeatDirection="Horizontal">
    26         </asp:CheckBoxList>
    27         <br />
    28         <asp:Label ID="Label3" runat="server" Text="房屋类型:"></asp:Label>
    29         <asp:CheckBox ID="CheckBox3" runat="server" AutoPostBack="True" OnCheckedChanged="CheckBox3_CheckedChanged" Text="全选" />
    30         <br />
    31         <asp:CheckBoxList ID="CheckBoxList3" runat="server" RepeatDirection="Horizontal">
    32         </asp:CheckBoxList>
    33         <br />
    34         <asp:Label ID="Label4" runat="server" Text="关键字:"></asp:Label>
    35         <asp:TextBox ID="TextBox1" runat="server"></asp:TextBox>
    36         <br />
    37         <br />
    38         <asp:Button ID="Button2" runat="server" OnClick="Button2_Click" Text="搜索" />
    39         <br />
    40     
    41         <asp:Repeater ID="Repeater1" runat="server">
    42             <HeaderTemplate>
    43                 <table width="840" border="0" cellspacing="1" cellpadding="1" bgcolor="#6600FF">
    44                   <tr>
    45                     <td width="120" height="30" align="center" valign="middle" bgcolor="#FFFFFF"></td>
    46                     <td width="120" align="center" valign="middle" bgcolor="#FFFFFF">关键字</td>
    47                     <td width="120" align="center" valign="middle" bgcolor="#FFFFFF">区域</td>
    48                     <td width="120" align="center" valign="middle" bgcolor="#FFFFFF" >使用面积</td>
    49                     <td width="120" align="center" valign="middle" bgcolor="#FFFFFF">租金</td>
    50                     <td width="120" align="center" valign="middle" bgcolor="#FFFFFF">租赁类型</td>
    51                     <td width="120" align="center" valign="middle" bgcolor="#FFFFFF">房屋类型</td>
    52                    </tr>
    53             </HeaderTemplate>
    54             <ItemTemplate>
    55                 <tr>
    56                     <td width="120" align="center" valign="middle" bgcolor="#FFFFFF"><a href="Update.aspx?id=<%#Eval("id") %>">编辑</a>&nbsp;<a href="Delete.aspx?id=<%#Eval("id") %>">删除</a></td>
    57                     <td width="120" height="30" align="center" valign="middle" bgcolor="#FFFFFF"><%#Eval("KeyWord") %></td>
    58                     <td width="120" align="center" valign="middle" bgcolor="#FFFFFF"><%#Eval("Area") %></td>
    59                     <td width="120" align="center" valign="middle" bgcolor="#FFFFFF"><%#Eval("SquareMeter") %></td>
    60                     <td width="120" align="center" valign="middle" bgcolor="#FFFFFF" ><%#Eval("Rent") %></td>
    61                     <td width="120" align="center" valign="middle" bgcolor="#FFFFFF"><%#Eval("RentType") %></td>
    62                     <td width="120" align="center" valign="middle" bgcolor="#FFFFFF"><%#Eval("HouseType") %></td>
    63                    </tr>
    64             </ItemTemplate>
    65             <FooterTemplate>
    66                 </table>
    67             </FooterTemplate>
    68         </asp:Repeater>
    69     
    70     </div>
    71         <asp:Button ID="Button1" runat="server" OnClick="Button1_Click" Text="添加数据" />
    72     </form>
    73 </body>
    74 </html>
    前台
      1 using System;
      2 using System.Collections.Generic;
      3 using System.Linq;
      4 using System.Web;
      5 using System.Web.UI;
      6 using System.Web.UI.WebControls;
      7 using System.Collections;
      8 
      9 public partial class Main : System.Web.UI.Page
     10 {
     11     private HouseDataContext context = new HouseDataContext();
     12     protected void Page_Load(object sender, EventArgs e)
     13     {
     14         if (!IsPostBack)
     15         {
     16             Repeater1.DataSource = context.House;
     17             Repeater1.DataBind();
     18           
     19             //  去重显示 方式一:
     20             var query = context.House;
     21             //通过操作集合去重显示
     22             foreach (House data in query)
     23             {
     24                 ListItem item = new ListItem();//造项
     25                 item.Text = data.Area;
     26                 if (!CheckBoxList1.Items.Contains(item))
     27                 {
     28                     CheckBoxList1.Items.Add(item);
     29                 }
     30             }
     31             foreach (House data in query)
     32             {
     33                 ListItem item = new ListItem();//造项
     34                 item.Text = data.RentType;
     35                 if (!CheckBoxList2.Items.Contains(item))
     36                 {
     37                     CheckBoxList2.Items.Add(item);
     38                 }
     39             }
     40             foreach (House data in query)
     41             {
     42                 ListItem item = new ListItem();//造项
     43                 item.Text = data.HouseType;
     44                 if (!CheckBoxList3.Items.Contains(item))
     45                 {
     46                     CheckBoxList3.Items.Add(item);
     47                 }
     48             }
     49             //去重显示 方式二:
     50             //List<string> list = context.House.Select(p => p.Area).Distinct().ToList();
     51             //foreach (string text in list)
     52             //{
     53             //    ListItem item = new ListItem();
     54             //    item.Text = text;
     55             //    CheckBoxList1.Items.Add(item);
     56             //}
     57             //List<string> listr = context.House.Select(p => p.RentType).Distinct().ToList();
     58             //foreach (string text in listr)
     59             //{
     60             //    ListItem item = new ListItem();
     61             //    item.Text = text;
     62             //    CheckBoxList2.Items.Add(item);
     63             //}
     64             //List<string> listh = context.House.Select(p => p.HouseType).Distinct().ToList();
     65             //foreach (string text in listh)
     66             //{
     67             //    ListItem item = new ListItem();
     68             //    item.Text = text;
     69             //    CheckBoxList3.Items.Add(item);
     70             //}
     71         }
     72     }
     73     protected void Button1_Click(object sender, EventArgs e)
     74     {
     75         Response.Redirect("Insert.aspx");
     76     }
     77     protected void CheckBox1_CheckedChanged(object sender, EventArgs e)
     78     {
     79         foreach (ListItem item in CheckBoxList1.Items)
     80         {
     81             item.Selected = CheckBox1.Checked;
     82         }
     83     }
     84     protected void CheckBox2_CheckedChanged(object sender, EventArgs e)
     85     {
     86         foreach (ListItem item in CheckBoxList2.Items)
     87         {
     88             item.Selected = CheckBox2.Checked;
     89         }
     90     }
     91     protected void CheckBox3_CheckedChanged(object sender, EventArgs e)
     92     {
     93         foreach (ListItem item in CheckBoxList3.Items)
     94         {
     95             item.Selected = CheckBox3.Checked;
     96         }
     97     }
     98     protected void Button2_Click(object sender, EventArgs e)
     99     {
    100         List<House> list = context.House.ToList();//造集合存放所有的数据
    101         ArrayList listArea = new ArrayList();//造集合
    102         ArrayList listRentType = new ArrayList();
    103         ArrayList listHouseType = new ArrayList();
    104         
    105         //第一个查询条件区域Area
    106         if (CheckBoxList1.SelectedIndex >= 0 && !CheckBox1.Checked)//有选中项并且不全选
    107         {
    108             foreach (ListItem item in CheckBoxList1.Items)//取出里面的选中值
    109             {
    110                 if (item.Selected)
    111                 { //如果被选中 取出里面的值 并赋给集合
    112                     listArea.Add (item.Text);
    113                 }
    114             }
    115             list = list.Where(p => listArea.Contains(p.Area)).ToList();//listArea是区域集合 包含这条数据Area的区域
    116         }
    117         //取第二个查询条件租赁类型RentType
    118         if (CheckBoxList2.SelectedIndex >= 0 && !CheckBox2.Checked)
    119         {
    120             foreach (ListItem item in CheckBoxList2.Items)
    121             {
    122                 if (item.Selected)
    123                 {
    124                     listRentType.Add(item.Text);
    125                 }
    126             }
    127             list = list.Where(p => listRentType.Contains(p.RentType)).ToList();
    128         }
    129         //取第三个查询条件房屋类型HouseType
    130         if (CheckBoxList3.SelectedIndex >= 0 && !CheckBox3.Checked)
    131         {
    132             foreach (ListItem item in CheckBoxList3.Items)
    133             {
    134                 if (item.Selected)
    135                 {
    136                     listHouseType.Add(item.Text);
    137                 }
    138             }
    139             list = list.Where(p => listHouseType.Contains(p.HouseType)).ToList();
    140         }
    141         //取第四个查询条件关键字KeyWord
    142         string keyword = TextBox1.Text;
    143         if(keyword != "")
    144         {
    145             list = list.Where(p => p.KeyWord.Contains(keyword)).ToList();
    146         }
    147         
    148         Repeater1.DataSource = list;
    149         Repeater1.DataBind();
    150     }
    151 }
    后台

    去重显示实现效果:

    多选查询显示效果:

    验证控件

    验证控件:    
        1、非空验证    
            RequiredFieldValidator
                属性:ErrorMessage:验证失败要显示的错误信息
                      Forecolor:文本的颜色
                      Display:显示的方式,默认Static占空间,Dynamic不占空间
                      ControlToValidate:要验证的控件
                      ValidaionGroup:验证分组
        2、对比验证
            CompareValidator
                属性:ErrorMessage:验证失败要显示的错误信息
                      Display:显示的方式
                      ControlToValidate:要验证的控件
                      ControlToCompare:要对比的控件
                      Type:按照什么类型对比
                      ValidaionGroup:验证分组
        3、范围验证
            RangeValidator
                属性:ErrorMessage:验证失败要显示的错误信息
                      Display:显示的方式
                      ControlToValidate:要验证的控件
                      MaximumValu:范围的最大值
                      MinimumValu:范围的最小值
                      Type:按照什么类型对比
                      ValidaionGroup:验证分组
        4、正则表达式验证
            RegularExpressionValidator
                属性:ErrorMessage:验证失败要显示的错误信息
                      Display:显示的方式
                      ControlToValidate:要验证的控件
                      ValidationExpression:要验证的正则表达式
                      ValidaionGroup:验证分组
        5、验证汇总控件:
            ValidationSummary
                属性:ValidaionGroup:验证分组
                  ShowSummary:以文本摘要的方式显示错误汇总信息
                  ShowMessageBox:以对话框的方式显示错误汇总信息

    前台

    验证控件只需修改控件中的属性,不用写后台代码

    实现效果:       

    上传文件

    <%@ Page Language="C#" AutoEventWireup="true" CodeFile="Default2.aspx.cs" Inherits="Default2" %>
    
    <!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>
            <br />
            <asp:FileUpload ID="FileUpload1" runat="server" />
    &nbsp;<asp:Button ID="Button1" runat="server" OnClick="Button1_Click" Text="上传" />
            <br />
            <br />
            <br />
    
            <div id="localImag" style=" 200px; height: 200px">
                <img id="preview" alt="预览图片" src="images/qiye.png" width="200" height="200" />
                <asp:FileUpload ID="PicLoad" Width="200px" Height="200px" style="position:relative; top:-200px; opacity:0" runat="server" onchange="javascript:setImagePreview(this,localImag,preview);"></asp:FileUpload>
    
            </div>
            <asp:Button ID="Button2" runat="server" OnClick="Button2_Click" Text="上传" />
    
            <script type="text/javascript">
                function setImagePreview(docObj, localImagId, imgObjPreview) {
                    if (docObj.files && docObj.files[0]) {
                        //火狐下,直接设img属性  
                        imgObjPreview.style.display = 'block';
                        imgObjPreview.style.width = '200px';
                        imgObjPreview.style.height = '200px';
    
                        //火狐7以上版本不能用上面的getAsDataURL()方式获取,需要一下方式    
                        imgObjPreview.src = window.URL.createObjectURL(docObj.files[0]);
                    }
                    else {
                        //IE下,使用滤镜  
                        docObj.select();
                        var imgSrc = document.selection.createRange().text;
    
                        //必须设置初始大小  
                        localImagId.style.width = "200px";
                        localImagId.style.height = "200px";
    
                        //图片异常的捕捉,防止用户修改后缀来伪造图片  
                        try {
                            localImagId.style.filter = "progid:DXImageTransform.Microsoft.AlphaImageLoader(sizingMethod=scale)";
                            localImagId.filters.item("DXImageTransform.Microsoft.AlphaImageLoader").src = imgSrc;
                        }
                        catch (e) {
                            alert("您上传的图片格式不正确,请重新选择!");
                            return false;
                        }
                        imgObjPreview.style.display = 'none';
                        document.selection.empty();
                    }
                    return true;
                }
            </script>  
            <br />
        </div>
        </form>
    </body>
    </html>
    前台
     1 using System;
     2 using System.Collections.Generic;
     3 using System.Linq;
     4 using System.Web;
     5 using System.Web.UI;
     6 using System.Web.UI.WebControls;
     7 
     8 public partial class Default2 : System.Web.UI.Page
     9 {
    10     protected void Page_Load(object sender, EventArgs e)
    11     {
    12 
    13     }
    14     protected void Button1_Click(object sender, EventArgs e)
    15     {
    16         //1、找到要上传文件的文件名
    17         string name = FileUpload1.FileName.ToString();
    18         //2、处理文件名
    19         string CLname = DateTime.Now.ToString("yyyyMMddHHmmssms")+name;
    20         //3、造一个要保存的路径
    21         string path = @"Files" + CLname;
    22         //4、处理路径为绝对路径
    23         string JDpath = Server.MapPath(path);
    24         //5、保存
    25         FileUpload1.SaveAs(JDpath);
    26     }
    27     protected void Button2_Click(object sender, EventArgs e)
    28     {
    29         //1、找到要上传文件的文件名
    30         string name = FileUpload1.FileName.ToString();
    31         //2、处理文件名
    32         string CLname = DateTime.Now.ToString("yyyyMMddHHmmssms") + name;
    33         //3、造一个要保存的路径
    34         string path = @"images" + CLname;
    35         //4、处理路径为绝对路径
    36         string JDpath = Server.MapPath(path);
    37         //5、保存
    38         FileUpload1.SaveAs(JDpath);
    39     }
    40 }
    后台

    实现效果:上传后:  

  • 相关阅读:
    指针的相关概念
    Linux库函数
    计算机组成
    常用校验码及示例
    判断文件是否被占用的三种方法
    服务主机superFetch占用磁盘过多
    renameTo()判断文件是否被占用(判断大文件是否完成拷贝这个动作)
    xshell下mysql数据库只导出表结构不导出数据
    Java_判断文件是否写入完成
    Java_监听文件夹或者文件是否有变动
  • 原文地址:https://www.cnblogs.com/mn-b/p/6693898.html
Copyright © 2011-2022 走看看