- ubuntu12.04环境下使用kvm ioctl接口实现最简单的虚拟机
- Ubuntu 通过无线网络安装Ubuntu Server启动系统后连接无线网络的方法
- 在Ubuntu上搭建网桥的方法
- ubuntu 虚拟机上网方式及相关配置详解
CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.
这篇CFSDN的博客文章一天精通asp.net的学习经验小结由作者收集整理,如果你对这篇文章有兴趣,记得点赞哟.
1、Validator 2、IsPostBack 3、AutoPostBack。控件离开焦点的时候自动Post。 4、repeater控件的使用。:Repeater控件比以前版本的asp.net好用了,只要 Eval就可以了,不用DataBinder.Eval(container.DataItem,"***"):了,只要Eval("Name")就可以,注意不能丢了前面的“#”。 <asp:Repeater ID="Repeater1" runat="server"> <HeaderTemplate> 嘎嘎嘎 </HeaderTemplate> <ItemTemplate> <%# Eval("Name")%> <%# Eval("Desc")%> </ItemTemplate> </asp:Repeater> protected void Button3_Click(object sender, EventArgs e) { List<Person> list = new List<Person>(); list.Add(new Person(){Name="芭芭拉",Desc="白牙呗"}); list.Add(new Person(){Name="奥巴马",Desc="黑黝黑"}); Repeater1.DataSource = list; Repeater1.DataBind(); } 5、DataList控件: (1)行的高亮选中 <asp:DataList ID="DataList1" runat="server" > <SelectedItemStyle BackColor="#FF6666" /> <ItemTemplate> <%# Eval("Name")%> <%# Eval("Desc")%> <asp:LinkButton ID="LinkButton1" runat="server" Text="选择" CommandName="select" /> </ItemTemplate> </asp:DataList> 核心是CommandName这个属性,可选值还有edit、delete等可选值,当按钮被点击的时候将会执行EditCommand、DeleteCommand等事件。 (2)行的在位编辑: <asp:DataList ID="DataList1" runat="server" oneditcommand="DataList1_EditCommand"> <SelectedItemStyle BackColor="#FF6666" /> <EditItemTemplate> <asp:TextBox runat="server" ID="t1" Text='<%# Eval("Name")%>' /> <asp:TextBox runat="server" ID="t2" Text='<%# Eval("Desc")%>' /> <asp:Button runat="server" Text="提交" CommandName="update" /> </EditItemTemplate> <ItemTemplate> <%# Eval("Name")%> <%# Eval("Desc")%> <asp:LinkButton ID="LinkButton1" runat="server" Text="编辑" CommandName="edit" /> </ItemTemplate> </asp:DataList> protected void DataList1_EditCommand(object source, DataListCommandEventArgs e) { DataList1.EditItemIndex = e.Item.ItemIndex; ReBind(); } private void ReBind() { List<Person> list = new List<Person>(); list.Add(new Person() { Name = "芭芭拉", Desc = "白牙呗" }); list.Add(new Person() { Name = "奥巴马", Desc = "黑黝黑" }); Repeater1.DataSource = list; Repeater1.DataBind(); DataList1.DataSource = list; DataList1.DataBind(); } (3)行的在位编辑并且提交修改 <asp:DataList ID="DataList1" runat="server" oneditcommand="DataList1_EditCommand" onupdatecommand="DataList1_UpdateCommand"> <SelectedItemStyle BackColor="#FF6666" /> <EditItemTemplate> <asp:TextBox runat="server" ID="t1" Text='<%# Eval("Name")%>' /> <asp:TextBox runat="server" ID="t2" Text='<%# Eval("Desc")%>' /> <asp:Button runat="server" Text="提交" CommandName="update" /> </EditItemTemplate> <ItemTemplate> <%# Eval("Name")%> <%# Eval("Desc")%> <asp:LinkButton ID="LinkButton1" runat="server" Text="编辑" CommandName="edit" /> </ItemTemplate> </asp:DataList> public partial class _Default : System.Web.UI.Page { protected void Page_Load(object sender, EventArgs e) { if (Session["PersonList"] == null) { List<Person> list = new List<Person>(); list.Add(new Person() { Name = "芭芭拉", Desc = "白牙呗" }); list.Add(new Person() { Name = "奥巴马", Desc = "黑黝黑" }); Repeater1.DataSource = list; Repeater1.DataBind(); Session["PersonList"] = list; } } protected void DataList1_EditCommand(object source, DataListCommandEventArgs e) { DataList1.EditItemIndex = e.Item.ItemIndex; ReBind(); } private void ReBind() { DataList1.DataSource = Session["PersonList"]; DataList1.DataBind(); } protected void DataList1_UpdateCommand(object source, DataListCommandEventArgs e) { TextBox nT1 = e.Item.FindControl("t1") as TextBox; TextBox nT2 = e.Item.FindControl("t2") as TextBox; //不要直接从DataList1.DataSource中取,因为取到的是null List<Person> list = Session["PersonList"] as List<Person>; Person curPerson = list[DataList1.EditItemIndex]; curPerson.Name = nT1.Text; curPerson.Desc = nT2.Text; DataList1.EditItemIndex = -1; ReBind(); } } 6 GridView控件 <asp:GridView ID="GridView1" runat="server" AllowSorting="True" AutoGenerateColumns="False" onrowcommand="GridView1_RowCommand" onsorting="GridView1_Sorting"> <Columns> <asp:ButtonField ButtonType="Button" CommandName="DingGou" HeaderText="订购" ShowHeader="True" Text="订购" /> <asp:ButtonField ButtonType="Button" CommandName="TuiDing" HeaderText="退订" ShowHeader="True" Text="退订" /> <asp:BoundField DataField="Name" HeaderText="名称" SortExpression="Name" /> <asp:BoundField DataField="Desc" HeaderText="描述" SortExpression="Desc" /> </Columns> </asp:GridView> protected void GridView1_RowCommand(object sender, GridViewCommandEventArgs e) { if (e.CommandName == "DingGou") { Debug.WriteLine("第"+e.CommandArgument+"行被订购"); } } protected void GridView1_Sorting(object sender, GridViewSortEventArgs e) { } 7、用户控件(UserControl) 通过向导创建一个UserControl,然后就可以任意编辑这个UserControl,而且还可以为UserControl增加属性、事件。使用的时候只要将控件直接从SolutionExplorer拖到页面上就可以。 8、继承控件 (1)通过向导创建一个WebCustomControl。 (2)定义自己应用界面。需要重载从Control类继承来的CreateChildControls方法,并在其中生成界面控件。如果用户定义的控件会在一个页面中反复使用,最好implements System.Web.UI.INamingContainer,它会为该控件创建一个唯一的命名空间。 (3)定义自己控件的消息处理函数。自己定义的控件含有两种类型的消息,一是包含的子控件所产生的消息,二是自定义的控件消息。 9、向工程中添加“Global Application Class”就可以添加Global.asax,在这里可以监听Application、Session的生命周期。 10、(1)Response.Redirect("newpage.aspx");客户端转发 (2)Server.Transfer("newpage.aspx");服务器端转发 11、web.config配置 (1) <appSettings> <add key="FTP" value="127.0.0.1"/> </appSettings> this.Title = WebConfigurationManager.AppSettings["FTP"]; (2) <connectionStrings> <add name="mydb" connectionString="jdbc:ddd"/> </connectionStrings> this.Title = WebConfigurationManager.ConnectionStrings["mydb"].ConnectionString; 12、BulletedList就是<ul><ol> 13、PostBack本质论 ASP.NET also adds two additional hidden input fields that are used to pass information back to the server. This information consists of the ID of the control that raised the event and any additional information that might be relevant. These fields are initially empty, as shown here: <input type="hidden" name="__EVENTTARGET" id="__EVENTTARGET" value="" /> <input type="hidden" name="__EVENTARGUMENT" id="__EVENTARGUMENT" value="" /> The __doPostBack() function has the responsibility for setting these values with the appropriate information about the event and then submitting the form. A slightly simplified version of the __doPostBack() function is shown here: <script language="text/javascript"> function __doPostBack(eventTarget, eventArgument) { var theform = document.Form1; theform.__EVENTTARGET.value = eventTarget; theform.__EVENTARGUMENT.value = eventArgument; theform.submit(); } </script> 14、跨页表单提交 在页1中指定按钮的PostBackUrl属性为WebForm1.aspx,这样表单就会提交到WebForm1.aspx了,然后在WebForm1.aspx中还可以取到前一页中所有的值: TextBox1.Text = PreviousPage.Title; 还可以将PreviousPage cast成更详细的页面子类。 15、取QueryString的方法: Request.QueryString["recordID"] 16、Server.UrlEncode(lstItems.SelectedItem.Text) 17、Multiview控件用来实现动态界面,Multiview里嵌套多个view控件,每个view控件里可以方式其他控件。通过控制Multiview控件的ActiveViewIndex属性来控制不同View的显示。 18、Wizard控件比Multiview控件更方面,更像一个TabControl 19、动态图片: 在pageload的事件中: Bitmap image = new Bitmap(300, 50); Graphics g = Graphics.FromImage(image); Response.ContentType = "image/png"; image.Save(Response.OutputStream, System.Drawing.Imaging.ImageFormat.Gif); 20 页面导航 创建SiteMap文件,修改SiteMap文件增加节点。 在页面上增加一个SiteMapDataSource,然后只要拖TreeView、Menu、SiteMapPath等控件上来,指定DataSource属性为SiteMapDataSource就可以了。 21 单值绑定 URL = "Images/picture.jpg"; this.DataBind(); <asp:CheckBox id="chkDynamic" Text="<%# URL %>" runat="server" /> 22 下拉列表框绑定 <asp:DropDownList ID="DropDownList1" runat="server" DataTextField="value" DataValueField="key"> </asp:DropDownList> IDictionary<string, string> dict = new Dictionary<string, string>(); dict["1"] = "aa"; dict["2"] = "bb"; DropDownList1.DataSource = dict; DropDownList1.DataBind(); 23 设定起始页:在aspx上点右键,选择“Set as startpage” 24 程序中数据库连接字符串的设置 (1)、web.config中加入: <connectionStrings> <add name="DBConnectionString" connectionString="server=192.168.88.128\SQLEXPRESS1;uid=sa;pwd=123456;database=CRM" providerName="System.Data.SqlClient"/> </connectionStrings> (2)、在IDE中拖放DataSource组件以后,在属性视图的ConnectionString属性中选择DBConnectionString即可。 (3)、程序中读取这个连接字符串的方法: System.Configuration.Configuration rootWebConfig = System.Web.Configuration.WebConfigurationManager.OpenWebConfiguration("~"); string connString = rootWebConfig.ConnectionStrings.ConnectionStrings["DBConnectionString"].ConnectionString; 24 制作简单的CRUD页面的步骤: (1)拖放一个SqlDataSource组件上来,设定好ConnectionString,命名组件为dsList。 (2)修改SqlDataSource组件的DeleteQuery属性为:delete from T_PSI_User where FId=@FId InsertQuery属性为:INSERT INTO T_PSI_User(FId, FUserName, FPassword) VALUES (NEWID(),@FUserName,@FPassword) SelectQuery为:select * from T_PSI_User UpdateQuery为:Update T_PSI_User set FUserName=@FUserName,FPassword=@FPassword where FId=@FId (3)拖放一个GridView组件上来,设定其DataSourceID属性为dsList。修改AllowPaging、AllowSorting、AutoGenerateDeleteButton、AutoGenerateEditButton属性为True。设定AutoGeneratedColumns属性为false。设定DataKeyNames属性为FId(这样哪怕隐藏了FId字段,Edit、delete功能也能正常执行了) (4)修改GridView的Columns属性,在弹出的对话框中点击【RefreshSchema】链接,这样在BoundField下就显示了FId、FName、FPassword三个字段,将FUserName和FPassword字段Add进来。 这样不用一行代码,有删、改功能的页面就做好了。下面来做“增”的功能。 (5)选择GridView组件,在智能提示中选择EditTemplete、然后选择“EmptyTemplete”,拖放一个FormView组件到EmptyTemplete中,选中Formview组件,在智能提示中设定DataSource为dsList。 (6)新建一个【新增】按钮,编辑其Click事件代码为: GridView1.DataSourceID = ""; GridView1.DataBind(); (7)设定FormView的ItemInserted事件代码为: RefreshList(); RefreshList()函数定义如下: GridView1.DataSourceID = "dsList"; GridView1.DataBind(); 这样“增”的功能就做好了,不过还是有缺憾,那就是显示出了不归我们管的FId字段,并且字段名、按钮都是英文的。 (8)选中,FormView组件,然后点击EditTemplete,选中InsertTemplete,这样就可以删除不需要的FId字段了,并且可以修改控件布局以及界面的语言文字。 (9)这样的话Insert界面中的“Cancel取消”按钮还是不能用,编辑FormView1的ItemCommand事件,编写如下的代码: if (e.CommandName == "Cancel") { RefreshList(); } 25 上面实现CRUD的方法有两个缺陷: (1)需要编写一个EmptyTemplete (2)很难对Edit的控件做定制 因此我们还是用ListUI和EditUI分置的方法来解决。步骤: 制作ListUI: (1)使用datasource、GridView,不过DataSource只要配置SelectQuery、DeleteQuery即可。 (2)GridView不自动生成Edit按钮。 (3)GridView生成一个ButtonField,标题为“编辑”,CommandName="EditInPage" protected void GridView1_RowCommand(object sender, GridViewCommandEventArgs e) { if (e.CommandName == "EditInPage") { int index = Convert.ToInt32(e.CommandArgument); Guid guid = (Guid)GridView1.DataKeys[index].Value; Server.Transfer("/Sys/SysUserEdit.aspx?Action=Edit&FId="+guid); } } (4)新增按钮的Onclick事件: Server.Transfer("/Sys/SysUserEdit.aspx?Action=Insert"); 制作EditUI: (1)拖一个DataSouce控件,按常规配置InsertCommand和UpdateCommand,配置SelectCommand为“SELECT * FROM [T_PSI_User] where 1<>1”,配置UpdateCommand为“” (2)拖一个FormView上来,并且修改EditTemplete和InsertTemplte(可以直接将EditTemplete修改后的拷贝到InsertTemplte,注意不要忘了修改Button的CommandName) (3)代码; protected void Page_Load(object sender, EventArgs e) { switch (Request["Action"]) { case "Edit": dsEdit.SelectCommand = "select * from T_PSI_User where FId=@FId"; dsEdit.SelectParameters.Clear(); dsEdit.SelectParameters.Add("FId", Request["FId"]); FormView1.ChangeMode(FormViewMode.Edit); break; case "Insert": FormView1.ChangeMode(FormViewMode.Insert); break; } } protected void FormView1_ItemInserted(object sender, FormViewInsertedEventArgs e) { GogoList(); } protected void FormView1_ItemUpdated(object sender, FormViewUpdatedEventArgs e) { GogoList(); } private void GogoList() { Server.Transfer("/Sys/SysUserList.aspx"); } } } 26、DropDownList实现基础资料选择器,比如在商品编辑中的选择计量单位: (1)拖一个针对T_MeasureUnit表的DataSource,比如名字为dsMeasureUnit。 (2)拖一个商品的Datasource,比如dsMerchan。 (3)拖一个FormView上来,并且设定其DataSource为dsMerchan (4)将一个DropDownList放到FormView中,因为只有这样才能设定DropDownList本身的绑定。 (5)选中DropDownList,在智能提示中选择“ConfigDateSource”,在这里配置上dsMeasureUnit。 (6)选中DropDownList,在智能提示中选择“EditDataBindings”,然后设定绑定到dsMerchan的FMeasureUnitId字段.
最后此篇关于一天精通asp.net的学习经验小结的文章就讲到这里了,如果你想了解更多关于一天精通asp.net的学习经验小结的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。
目录 前言 style-loader css-loader sass-loader postcss-loader babel-l
目录 1、简单动态字符串(SDS) 2、链表 3、字典 哈希表 哈希表节点 字典 4、跳跃表
JS运行三部曲 js运行代码共分三步 语法分析 预编译 解释执行 JavaScript代码在运行时,首先会进行语法分析,通篇检查代码是否存在低级错误,然后进行预编译,整理内
目录 +拼接方式 sprintf函数 Join函数 buffer.Builderbuffer.WriteString函数 buffer.B
下面整理下python有哪些方式可以读取数据文件。 1. python内置方法(read、readline、readlines) read() : 一次性读取整个文件内容。推荐使用re
背景 项目中的流程监控,有几种节点,需要监控每一个节点是否超时。按传统的做法,肯定是通过定时任务,去扫描然后判断,但是定时任务有缺点:1,数据量大会慢;2,时间不好控制,太短,怕一
目录 1. 提炼函数 2. 合并重复的条件片段 3. 把条件分支语句提炼成函数 4. 合理使用循环 5. 提前让函数退出代替嵌套条件分支
开始之前,pandas中dataframe删除对象可能存在几种情况 1、删除具体列 2、删除具体行 3、删除包含某些数值的行或者列 4、删除包含某些字符、文字的行或者列 本文就针对这四种情况探讨
setData setData 是小程序开发中使用最频繁的接口,也是最容易引发性能问题的接口。在介绍常见的错误用法前,先简单介绍一下 setData 背后的工作原理。 工作原理 小程序的视图层
下面是五种实现斐波那契数列的方法 循环 ? 1
一,分析代码运行时间 第1式,测算代码运行时间 平凡方法 快捷方法(jupyter环境) 第2式,测算代码多次运行平均时间 平凡方法 快捷方法(jupyter环境) 第
python之成为图像处理任务的最佳选择,是因为这一科学编程语言日益普及,并且其自身免费提供许多最先进的图像处理工具。本文主要介绍了一些简单易懂最常用的python图像处理库。 当今世界充满了各种
流式布局 采用流式布局会将元素按从左到右的顺序排列,如果一个元素在一行中放不下,那这个元素会另起一行依然按照从左到右的顺序排列 示例: 代码 public class Tes
@PropertySource 作用是:对自定义的properties文件加载 使用:@PropertySource(value={"classpath:people.properti
实现消息队列的两种方式 apache activemq官方实例发送消息 直接在apache官网http://activemq.apache.org/download-archives.html下
常用配置 以下配置能使用File -> New Projects Settings -> Settings for New Projects进行配置的尽量用这个配置,因为这个配置是作用
摘要: 开发者开发部署web应用时通常使用tomcat服务器,很多初学者只懂得在开发工具上配置,但离开了开发工具,自己手动配置部署,并让一个项目跑起来,你会了吗。小编也遇到过这样的困扰。网上查找的
1. 字符串的翻转 利用切片 ? 1
cookie和session在java web开发中扮演了十分重要的作用,本篇文章对其中的重要知识点做一些探究和总结。 1.cookie存在于浏览器 随意打开一个网址,用火狐的调试工具,随意选取
1、使用内置的tomcat,通过java -jar的方式启动 比如:java -jar bms.jar 但是这种启动方式 一旦关闭控制台 或者crtl+c 退出 此时应用就关闭了
我是一名优秀的程序员,十分优秀!