在老外的站上看到解决的好方法,故简单编译之:
在一个asp.net 的应用中,经常要动态修改页面的标题,一个典型的例子就是,在一个页面导航的控件中,希望用户点选哪一个连接,在页面的title里就显示相关的内容,举个例子,比如一个网站,有如下的网站架构:
有图书分类,下面再有中国图书,外国图书分类,则一般可以用树形或者asp.net 2.0的新增加的导航栏控件
(sitemap),来实现,比如
图书--->中国图书;
图书---->外国图书
等,而如果这个时候,能在页面的<title>部分,也能显示比如"图书-->中国图书"这样,那就更加直观明显了,
在asp.net 2.0中,我们可以使用<head>部分的服务端控件来实现了,首先,要添加标记
<head runat="server">
然后可以在page_load事件中,以如下形式改边其title的内容了,如
page.header.title = "the current time is: " & datetime.now.tostring()
,也可以简单写成page.title.
然后,我们可以通过这样的办法,将其于sitemap控件结合了,实现方法如下:
const default_unnamed_page_title as string = "untitled page"
const default_page_title as string = "welcome to my website!!"
protected sub page_load(byval sender as object, byval e as system.eventargs) handles me.load
'set the page's title, if needed
if string.isnullorempty(page.title) orelse page.title = default_unnamed_page_title then
if sitemap.currentnode is nothing then
page.title = default_page_title
else
page.title = getpagetitlebasedonsitenavigation()
'can also use the following if you'd rather
'page.title = getpagetitlebasedonsitenavigationusingrecursion(sitemap.currentnode)
end if
end if
end sub
private function getpagetitlebasedonsitenavigation() as string
if sitemap.currentnode is nothing then
throw new argumentexception("currentnode cannot be nothing")
end if
'we are visiting a page defined in the site map - build up the page title
'based on the site map node's place in the hierarchy
dim output as string = string.empty
dim currentnode as sitemapnode = sitemap.currentnode
while currentnode isnot nothing
if output.length > 0 then
output = currentnode.title & " :: " & output
else
output = currentnode.title
end if
currentnode = currentnode.parentnode
end while
return output
end function
在上面的代码中,首先预定义了两个常量,然后逐步建立sitemap的结点,一开始结点是null的,然后再调用getpagetitlebasedonsitenavigation() 这个过程,在每建立一个sitemap的结点时,用字符串进行连接,最后返回给page.title即可实现,当然也可以用递归实现.
新闻热点
疑难解答
图片精选