2008年06月10日

于题目的问题,我一直很诧异,诧异到坐在那里对着屏幕发呆冒汗!因为以前明明可以返回XmlNode的,但是这次实在不行。

网上搜了一通...音信全无。

在今天交了毕业论文之后,我心情大爽大震!

于是发现了问题:

1、 <Resume xmlns="http://ns.zhaopin.com/resumes">

2、<Resume>

上面的1和2的区别在于XML文档1的根节点多了xmlns属性,就是它惹得祸!

好吧,让我们在处理XML文档之前把这个属性去掉吧,我用的是一个很白痴的很简单但很好用的方法:字符串处理。

StreamReader sr = new StreamReader(Server.MapPath("") + "\\1.xml");
string tempXML = sr.ReadToEnd().ToString().Replace("xmlns=\"http://ns.zhaopin.com/resumes\"", "");
sr.Close();
StreamWriter sw = new StreamWriter(Server.MapPath("") + "\\1.xml", false, System.Text.Encoding.UTF 8) ;
sw.WriteLine(tempXML);
sw.Close();

上面的代码的意思就是说把1.xml中的字符都读出来,然后把刚说的那个讨厌的属性给替换掉,然后重新写入1.xml。

好吧,现在这个1.xml就听话了,在我们SelectSingleNode()的时候返回null了。

Tags: .
2008年01月08日

从装了Windows 2003之后,在本地开发网站的时候部署到IIS上后总是提示“无法找到该页”的错误,但是访问html和图片文件的时候却没有问题,一直诧异中,却一直没理会。因为自从VS2005之后它内置的服务器就可以帮助我们做我们想要做的网站调试和浏览了。但问题终归是问题,不能一直逃避不去解决,今日偶然发现了解决的办法,放在这里以留纪念。

Windows 2003毕竟是服务器系统,安全性要求较高,所以就默认设置了asp和aspx这些脚本页面不许执行了。

其实很简单,只需要一幅图就可以完全说明问题,不必我在这里罗罗嗦嗦了。

iis.JPG

2007年12月30日

Asp.net 1.1开始,我们就开始使用DataGrid、DataList、Repeater控件,到了Asp.net 2.0又增加了GridView控件。GridView控件在DataGrid上做了优化和改进,功能很强大,但是自定义性不够强。Repeater自定义性非常高。而DataList则兼而有之,其他方面本文不谈。这里就说下怎么给DataList分页。

给DataList分页有两个办法:1、自己写 2、用第三方控件(如AspNetPager

使用第三方控件的方法我就不说了,这里主要说说如何自己实现分页方法。

我的DataList分页方法的核心原理是利用PagedDataSource对象,PagedDataSource类封装了DataGrid 控件的属性,这些属性使 DataGrid 可以执行分页,下面是PagedDataSource的公共属性:

AllowCustomPaging 获取或设置指示是否启用自定义分页的值。
AllowPaging 获取或设置指示是否启用分页的值。
Count 获取要从数据源使用的项数。
CurrentPageIndex 获取或设置当前页的索引。
DataSource 获取或设置数据源。
DataSourceCount 获取数据源中的项数。
FirstIndexInPage 获取页中的第一个索引。
IsCustomPagingEnabled 获取一个值,该值指示是否启用自定义分页。
IsFirstPage 获取一个值,该值指示当前页是否是首页。
IsLastPage 获取一个值,该值指示当前页是否是最后一页。
IsPagingEnabled 获取一个值,该值指示是否启用分页。
IsReadOnly 获取一个值,该值指示数据源是否是只读的。
IsSynchronized 获取一个值,该值指示是否同步对数据源的访问(线程安全)。
PageCount 获取显示数据源中的所有项所需要的总页数。
PageSize 获取或设置要在单页上显示的项数。
VirtualCount 获取或设置在使用自定义分页时数据源中的实际项数。

那么如何使用 PagedDataSource对象进行DataList分页呢?(网上有很多的讲DataList分页的文章,有一些是糊弄人的,有的还无法起作用,我被骗过一次,本文是我经过个人实践经验得到,可以顺利执行。希望对大家有所帮助。)

现在开始拉!

第一步,取出数据到datatable中,然后获得dataview,付给PagedDataSource对象

DataView objView = objTable.DefaultView;
PagedDataSource objPds = new PagedDataSource();
objPds.DataSource = objView;

第二步,PagedDataSource对象objPds的设置

objPds.AllowPaging = true;
objPds.PageSize = 4;
objPds.CurrentPageIndex = int.Parse(ViewState["pageindex"].ToString());

上面的这两段代码都是写在BindData()函数中的,供每次点击分页按钮时调用。BindData()函数如下:

private void BindData()
{
string sql = "SELECT * From team";

DataTable objTable = data.GetDataTable(sql);
if (objTable != null && objTable.Rows.Count > 0)
{
DataView objView = objTable.DefaultView;
PagedDataSource objPds = new PagedDataSource();
objPds.DataSource = objView;

objPds.AllowPaging = true;
objPds.PageSize = 4;
objPds.CurrentPageIndex = int.Parse(ViewState["pageindex"].ToString());

if (!objPds.IsFirstPage)
{
lkPre.Visible = true;
}
else
{
lkPre.Visible = false;
}

if (!objPds.IsLastPage)
{
lkNext.Visible = true;
}
else
{
lkNext.Visible = false;
}

dlData.DataSource = objPds;
dlData.DataBind();
}
}

到此为止,我们已经将数据交给了PagedDataSource,剩下的分页将利用PagedDataSource 进行处理。可能大家注意到了,这个数据交付是完整的数据交付,如果数据量很大会造成一定的效率低下,不过这里暂时不考虑这个问题。有兴趣的朋友可以一起探讨一下。

上面的第三行代码中的 ViewState["pageindex"] 是用来控制PagedDataSource的当前页的,我们在Page_Load事件中和第三步将要将的函数中来具体讲解如何利用 ViewState["pageindex"]控制当前页。

BindData()函数中后面的部分是控制向前向后按钮的显隐的,不再多说。

第三步,分页控制

第二步中说过利用 ViewState["pageindex"] 来控制当前页,为了在页面加载的时候就显示第一页,我们当然要在Page_load事件中将 ViewState["pageindex"]置为0。

protected void Page_Load(object sender, EventArgs e)
{
if (!IsPostBack)
{
ViewState["pageindex"] = "0";
BindData(); }
}

我们需要加两个按钮(Previous、Next)来点击进行分页控制。

<asp:DataList ID="dlData" runat="server" RepeatColumns="4" >
<ItemTemplate>
<asp:Label ID="lblName" runat="server" /><br />
<asp:Label ID="lblTime" runat="server" />
</ItemTemplate>
</asp:DataList>
<asp:linkbutton ID="lkPre" OnCommand="IndexChanging" CommandArgument="pre" runat="server" >PREVIOUS PAGE></asp:linkbutton>
<asp:linkbutton ID="lkNext" OnCommand="IndexChanging" CommandArgument="next" runat="server" >NEXT PAGE</asp:linkbutton>

两个按钮的 OnCommand都是IndexChanging()函数,我们通过CommandArgument(pre和next)来区分到底是向前翻还是向后翻。下面是IndexChanging()函数

protected void IndexChanging(object sender, EventArgs e)
{
string strCommand = ((LinkButton)sender).CommandArgument.ToString();

int pageindex = int.Parse(ViewState["pageindex"].ToString());

if (strCommand == "pre")
{
pageindex = pageindex - 1;
}
else
{
pageindex = pageindex + 1;
}

ViewState["pageindex"] = pageindex;

BindData();
}

至此,我们的分页函数已经写完了。这里还有一些东西没有说,比如显示一共多少条记录,当前第几页,一共多少页以及每一页的页码。相信看懂了上面所说的后这些东西还是容易写出来的。

总结一下,我们在前台写好DataList等待数据,而数据是由PagedDataSource提供的,分页通过我们新加的两个ImageButton来控制ViewState进而达到控制PagedDataSource的CurrentPageIndex来实现的。所以,其实DataList也没干啥事,就是显示了每一页的数据而已。有一点需要说明,PagedDataSource的CurrentPageIndex是从0开始的,这也是为什么在Page_load事件中要讲ViewState置为0而不是1的缘故。

OK了~听着周杰伦的“阳光宅男”写完了这篇blog,希望对大家有所帮助 。

Tags: ,,,,,,,,,.
2007年12月06日

VS2008发布了,下载了 Visual Web Developer 2008用了下,感觉不错,让我们可以调试JS,可以设计CSS,可以有像DreamWaver一样的分离视图,并且其速度较之2005感觉也快了许多。2005做的网站可以用2008直接打开继续开发,并无大碍,不像2003转成2005时那样让人提心吊胆。

和VS2008一起发布的是Framework 3.5,但是做完网站之后在IIS的ASP.Net配置里面却看不到有Framework 3.5的选项,让我十分诧异。。。

经过一系列的调查,发现。其实Framework 3.5和ASP.Net Framework 3.5是不一样的,ASP.Net Framework 3.5只是一个非官方性的叫法,真正的叫法叫做Asp.Net Running on Framework 3.5

原来如此, Asp.Net Running on Framework 3.5其实也没有太大的革新,不过集成了Ajax,并且增加了几个控件给我们用。所以,在我们发布网站的时候依然可以继续我们的Framework 2.0!

附:Asp.Net官方网站 http://asp.net

Asp.Net Running on Framework 3.5 及相关资料下载地址:用你犀利的眼睛在官方网站上尽情发现吧!

Asp.Net之父 Scott Guthrie 博客中文版: http://blog.joycode.com/scottgu/

Asp.Net之父 Scott Guthrie 博客英文版: http://weblogs.asp.net/scottgu/