c#编程小技巧1.docx
- 文档编号:8096268
- 上传时间:2023-01-28
- 格式:DOCX
- 页数:97
- 大小:90.18KB
c#编程小技巧1.docx
《c#编程小技巧1.docx》由会员分享,可在线阅读,更多相关《c#编程小技巧1.docx(97页珍藏版)》请在冰豆网上搜索。
c#编程小技巧1
一、最小化窗口
点击“X”或“AltF4”时,最小化窗口,如:
protectedoverridevoidWndProc(refMessagem)
{
constintWM_SYSCOMMAND=0x0112;
constintSC_CLOSE=0xF060;
if(m.Msg==WM_SYSCOMMAND&&(int)m.WParam==SC_CLOSE)
{
//Userclickedclosebutton
this.WindowState=FormWindowState.Minimized;
return;
}
base.WndProc(refm);
}
二、如何让Foreach循环运行的更快
foreach是一个对集合中的元素进行简单的枚举及处理的现成语句,用法如下例所示:
usingSystem;
usingSystem.Collections;
namespaceLoopTest
{
classClass1
{
staticvoidMain(string[]args)
{
//createanArrayListofstrings
ArrayListarray=newArrayList();
array.Add("Marty");
array.Add("Bill");
array.Add("George");
//printthevalueofeveryitem
foreach(stringiteminarray)
{
Console.WriteLine(item);
}
}
}
你可以将foreach语句用在每个实现了Ienumerable接口的集合里。
如果想了解更多foreach的用法,你可以查看.NETFrameworkSDK文档中的C#LanguageSpecification。
在编译的时候www.ks-,C#编辑器会对每一个foreach区域进行转换。
IEnumeratorenumerator=array.GetEnumerator();
try
{
stringitem;
while(enumerator.MoveNext())
{
item=(string)enumerator.Current;
Console.WriteLine(item);
}
}
finally
{
IDisposabled=enumeratorasIDisposable;
if(d!
=null)d.Dispose();
}
这说明在后台,的管理会给你的程序带来一些增加系统开销的额外代码。
三、将图片保存到一个XML文件
WinForm的资源文件中,将PictureBox的Image属性等非文字内容都转变成文本保存,这是通过序列化(Serialization)实现的,
例子:
//
usingSystem.Runtime.Serialization.Formatters.Soap;
Streamstream=newFileStream("E:
\\Image.xml",FileMode.Create,FileAccess.Write,FileShare.None);
SoapFormatterf=newSoapFormatter();
Imageimg=Image.FromFile("E:
\\Image.bmp");
f.Serialize(stream,img);
stream.Close();
四、屏蔽CTRL-V
在WinForm中的TextBox控件没有办法屏蔽CTRL-V的剪贴板粘贴动作,如果需要一个输入框,但是不希望用户粘贴剪贴板的内容,可以改用RichTextBox控件,并且在KeyDown中屏蔽掉CTRL-V键,例子:
privatevoidrichTextBox1_KeyDown(objectsender,System.Windows.Forms.KeyEventArgse)
{
if(e.Control&&e.KeyCode==Keys.V)
e.Handled=true;
}
ps:
网上摘抄,看了以后感觉不错,以后碰见好的再陆续发布
Tags:
dotnet技术,c#开发技术
ASP.NET2.0中使用webpart系列控件
Dot-Net技术|阅读(144)|评论(0)
Oct
29
2005
[此文来源于互联网,牛C网只负责收集整理]
在现在的网站设计中,更强调的是用户的个性化设置,让用户可以自由的设置符合自己喜好的页
昆山废面成为网站开发人员的头号难题,不过现在看来这个难题微软帮我们解决了。
在2.0中新增加了一系列webpart控件,可以让用户很方便地对网页的各区域布局进行调整。
在一些web应用程序中,如果用户想自定义页面布局,比如一个新闻发布系统,想让左,中,右三栏的位置进行调换的话,就可以使用webpart控件。
下面,我们来看下2.0中webpart系列控件的一些基本用法。
首先,在2005中的工具箱中,可以找到如下图所示的webpart系列控件,有很多个,限于篇幅,本文介绍其中的一些重要的控件:
在webpart系列控件中,其中的webpartmanager控件用于统一管理各webpart控件。
而webpartzone控件,则是提供了各区域划分,在这些区域中,用户可以往里面放置各式各样的控件,而当运行的时候,用户可以移动的就是这些webpartzone控件所在的区域。
为增强认识,我们先做个简单的例子。
1、首先使用2005beta2(或者RC1)新建一个web站点,
2、往窗体中拖拉一个webpartmanager控件,再建一个3列1行的表格,分别往每个单元格里拖拉一个webpartzone控件,如下图:
3、往webpartzone1中拖拉放一个日历控件,并为这个日历控件选择一个合适的样式
4、切换到代码视图状态,将日历控件的title属性改为:
today’sdate。
注意的是,日历控件本身没有title属性,但当一个控件加入到webpartzone区域中去后,则该控件被自动包装为GenericWebPart类型控件,这些类型的控件有title属性。
5、这时,我们可以按F5来运行该程序,运行如下图所示,可以看到,区域的右上角有最小化和关闭,恢复的按钮。
接下来,我们介绍如何在webpart系列控件中,使用用户自定义的控件。
1、首先,我们为工程项目增加一个"google.ascx"的控件,并且在images目录下,添加google那张著名的logo图片。
接着,往窗体中添加一个2*2行的表格,再往其中的一个单元格添加一个image图象控件,指定其图象为google.gif,再添加一个文本框,一个按钮,如下图所示,其中,括号内的是该控件的名称:
3、在btnsearch按钮的click事件中写入如下代码:
Response.Write(Page.IsValid)
DimqueryStrAsString=HttpUtility.UrlEncode(txtSearch.Text)
Response.Redirect("&queryStr)
EndSub
4、这时,将写好的google.ascx控件,整个拖拉到我们刚才建立好的表格中的中间那个单元格,如下图所示:
我们并且修改代码如下,修改其名称为googleserach:
<uc1:
Googletitle="GoogleSearch"runat="server"ID="Google1"/>
接下来,F5运行,可以看到,可以在googlesearch所在的webpart里进行google搜索了。
同时,如果觉得webpart的那些关闭,恢复,最小化的按钮不大好看,还可以自定义按钮,比如在images目录下,添加下面的图片:
然后,在webpartzone1的属性中,指定如下的属性就可以了。
CloseVerb.ImageUrl="Images/CloseVerb.gif"
EditVerb.ImageUrl="Images/EditVerb.gif"
MinimizeVerb.ImageUrl="Images/MinimizeVerb.gif"
RestoreVerb.ImageUrl="Images/RestoreVerb.gif"
使webpart动起来
上面设计的webpart还没能动起来,要让webpart动起来的话,必须要将webpar设置为designdisplay模式。
先为webpart添加下面的radiobutton选择框
<asp:
RadioButtonListID="rblMode"runat="server"AutoPostBack="True">
<asp:
ListItem>BrowseDisplayMode</asp:
ListItem>
<asp:
ListItem>DesignDisplayMode</asp:
ListItem>
</asp:
RadioButtonList>
并且在code-behind的代码中,写入如下代码:
ProtectedSubRadioButtonList1_SelectedIndexChanged(ByValsenderAsObject,_ByValeAsSystem.EventArgs)_HandlesrblMode.SelectedIndexChanged
SelectCaserblMode.SelectedIndex
Case0:
WebPartManager1.DisplayMode=WebPartManager.BrowseDisplayMode
Case1:
WebPartManager1.DisplayMode=WebPartManager.DesignDisplayMode
EndSelect
EndSub
运行上面代码,选择designdisplaymode,则可以象下图那样,自由拖动webpart,
要注意的是,当移动各webpart的位置后,即使关掉浏览器,下次重新打开时,依然可以看到各个控件保持原来的位置。
其实,2.0是使用在aspnetdb.mdf中的一个叫aspnet_PersonalizationPerUser的表来保存数据的,表的结构如下所示:
FieldValue
Id928e121a-4042-4fb4-9520-21210b9b37c1
PathId7c3b5dc0-04d0-48a2-bbb2-2b70286f22fe
UserId9bff14df-024f-4bda-9a0a-b4a19ab9e387
PageSettings<Binarydata>
LastUpdatedDate10/06/20054:
44:
05AM
如果想恢复各控件的原来位置,只需要将该数据表中相应的行删除掉就可以了。
但有个问题是,如果使用每一个webpart的关闭按钮,则很难再将其恢复(当然删除数据表中的行,但十分麻烦)。
在2.0中,提供了另一种webpart,叫做catlogzone控件,下面介绍其用法:
1、往窗体中拖拉一个catlogzone控件,如下图所视。
2、往该catlogzone控件区域中,再拖放三个webpart系列的控件,分别是DeclarativeCatalogPart,PageCatalogPart,andImportCatalogPart,如下图所示。
其中,DeclarativeCatalogPart控件的作用是,显示目前页面上有哪些可以用的webpart控件;PageCatalogPart的作用是,可以让用户通过勾选的方式,选定将哪些控件添加转移到其他webpart区域中去。
ImportCatalogPart则可以通过外部磁盘文件的方式,加载其他做好了的webpart部件。
3、在radiobutton区域中,修改以下代码,增添一个catalogdisplay的显示模式:
<asp:
RadioButtonListID="rblMode"runat="server"AutoPostBack="True">
<asp:
ListItem>BrowseDisplayMode</asp:
ListItem>
<asp:
ListItem>DesignDisplayMode</asp:
ListItem>
<asp:
ListItem>CatalogDisplayMode</asp:
ListItem>
</asp:
RadioButtonList>
然后,在code-behind的代码中,将代码修改为如下:
ProtectedSubrblMode_SelectedIndexChanged(_
ByValsenderAsObject,_
ByValeAsSystem.EventArgs)_
HandlesrblMode.SelectedIndexChanged
SelectCaserblMode.SelectedIndex
Case0:
WebPartManager1.DisplayMode=WebPartManager.BrowseDisplayMode
Case1:
WebPartManager1.DisplayMode=WebPartManager.DesignDisplayMode
Case2:
WebPartManager1.DisplayMode=WebPartManager.CatalogDisplayMode
EndSelect
EndSub
4、在DeclarativeCatalogPart任务菜单上,点击右上角的智能感知按钮,然后选"edittemplates"的链接,进入模版编辑状态,如下图:
再往其中的webpartstemplate区域中拖拉一个google.ascx控件,如下图,这将允许用户在运行时,可以自由地往页面增加这样的google搜索控件。
5、然后修改代码如下:
<ZoneTemplate>
<asp:
DeclarativeCatalogPartID="DeclarativeCatalogPart1"runat="server">
<WebPartsTemplate>
<uc1:
Googletitle="GoogleSearch"ID="Google2"runat="server"/>
</WebPartsTemplate>
</asp:
DeclarativeCatalogPart>
6、运行程序,可以看到,当选择catalogdisplaymode时,会显示如下图所示的catalogzone,其中列出了当前可用的有哪些webpart控件,我们可以把这个google的控件加到其他的webpart区域,也可以尝试将已经存在的webpart控件关闭,然后在catalogzone区域中的控件列表中,把它们再加回到页面中去。
此外,在运行期间,还可以动态地修改webpart控件的外观等属性,如下:
1)往窗体中添加一个editorzone的区域控件,往其中再拖放一个appearanceEdiotrPart控件,该控件可以在运行时,让用户动态改变各webpart控件的属性。
2)我们再修改radiobutton选择框的代码如下,则加一个编辑模式:
<asp:
RadioButtonListID="rblMode"runat="server"AutoPostBack="True">
<asp:
ListItem>BrowseDisplayMode</asp:
ListItem>
<asp:
ListItem>DesignDisplayMode</asp:
ListItem>
<asp:
ListItem>CatalogDisplayMode</asp:
ListItem>
<asp:
ListItem>EditDisplayMode</asp:
ListItem>
</asp:
RadioButtonList>
3)修改code-behind代码如下:
ProtectedSubrblMode_SelectedIndexChanged(ByValsenderAsObject,ByValeAsSystem.EventArgs)_
HandlesrblMode.SelectedIndexChanged
SelectCaserblMode.SelectedIndex
Case0:
WebPartManager1.DisplayMode=WebPartManager.BrowseDisplayMode
Case1:
WebPartManager1.DisplayMode=WebPartManager.DesignDisplayMode
Case2:
WebPartManager1.DisplayMode=WebPartManager.CatalogDisplayMode
Case3:
WebPartManager1.DisplayMode=WebPartManager.EditDisplayMode
EndSelect
EndSub
4)运行程序,选择editdisplaymode模式,这时,会发现每个控件的右上角,会多了一个"edit"的按钮,点该按钮,弹出如下图的窗体,用户可以修改每个控件的外观等属性。
最后,我们看下,webpart控件之间还可以进行相互之间的通信,下面的例子中,要实现的是,在一个日历控件中点选某一个日期,会在已经做好的googlesearch的webpart控件的文本框中显示其日期,达到通信的目的,下面介绍其实现步骤:
1、为了使两个webpart控件之间进行通信,必须先声明一个公共的接口。
往工程项目里增加一个叫ISelectedDate.vb的类文件,放在app_code目录下,写入如下代码:
ImportsMicrosoft.VisualBasic
PublicInterfaceISelectedDate
ReadOnlyPropertySelectedDate()AsDate
EndInterface
这里,我们返回一个只读的日期属性selectedDate.
2、再创建一个日历控件CalendarUC.ascx,其中拖拉一个普通的日历控件即可。
然后写入如下代码:
PartialClassCalendarUC_ascx
InheritsSystem.Web.UI.UserControl
ImplementsISelectedDate
PublicReadOnlyPropertySelectedDate()AsDateImplementsISelectedDate.SelectedDate
Get
ReturnCalendar1.SelectedDate.Date
EndGet
EndProperty
<ConnectionProvider("SelectedDate","SelectedDate")>_
PublicFunctionGetSelectedDate()AsISelectedDate
ReturnMe
EndFunction
EndClass
上面的代码,首先实现了已经声明了的IselectedDate接口,要留意的是<ConnectionProvider("SelectedDate","SelectedDate")>中的写法。
由于在这个例子中,日历控件要为其他的控件提供信息,因此,该日历控件是一个provider(提供者),而另外的接收信息的控件,是consumer(消费者)。
而两者为了要通信,必须要提供一个通信接入点,就象一个电插头,要找到合适的电插板一样。
因此,<ConnectionProvider("SelectedDate","SelectedDate")>中的第一个参数,定义了两者的接口点,第二个参数,则是要传递给consumer的参数,本例是selectedDate。
3、接下来,我们在已经做好的google.ascx控件的代码中,编写如下代码:
Private_selectedDateAsISelectedDate
<ConnectionConsumer("SelectedDate","SelectedDate")>_
SubsetSearchText(ByValSearchTextAsISelectedDate)
Me._selectedDate=SearchText
EndSub
ProtectedSubPage_PreRender(ByValsenderAsObject,ByValeAsSystem.EventArgs)HandlesMe.PreRender
If_selectedDateIsNotNothingThen
txtSearch.Text=_selectedDate.SelectedDate.ToShortDateString
EndIf
EndSub
可以看到<ConnectionConsumer("SelectedDate","SelectedDate")>的定义必须和provider中的定义一样。
4、再修改如下代码,将两个控件的命名变得通俗易懂
<ZoneTemplate>
<uc1:
Googletitle="GoogleSearch"runat="server"ID="Google1"/>
<uc3:
CalendarUCtitle="CalendarWebPart"runat="server"ID="CalendarUC1"/>
</ZoneTemplate>
5、最后,为了使两者能互相通信,必须在default.aspx页中修改如下代码:
<asp:
WebPartManagerID="WebPartManager1"runat="server">
<StaticC
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- c# 编程 技巧