我用Menu控件做页面导航,当我选中一个没有指定url的项时,被选中的菜单项按照我设定的变了色。可是当我选中一个有url的项时,由于页面被导航到了指定的页面,页面被重新加载,新加载的页面虽然也有这个菜单,但是已经没有变色了。我找了半天也没找到该怎样在后台设置Menu控件被选中的项。到底该怎么设置哪?
[分析1]
看来只好把带有Menu控件的Header放在单独的frame中,然后用target使另一个页面转向就不会导致页面重新加载了。而且还避免了页面元素的重复执行,提高了页面的执行效率。
但是如果这样,当页面很长的时候,Header部分不动,只有下面的部分动,太难看了
[对分析1的解决]
在<head>与</head>之间加
<style type="text/css">
frameset
{
overflow: scroll;
}
</style>
[对上面的质疑]
但是由于为了防止下面的frame出现滚动条,代码只有写成这样:
<FRAMESET ROWS="15%,*" marginwidth="0" marginheight="0" framespacing="0" frameborder="no" border="0">
<FRAME SCROLLING="NO" name="header" SRC="Header.aspx">
<FRAME SCROLLING="NO" name="content" SRC="content.htm">
</FRAMESET>
<FRAME SCROLLING="NO" name="header" SRC="Header.aspx">
<FRAME SCROLLING="NO" name="content" SRC="content.htm">
</FRAMESET>
所以在执行的时候,content.htm中的内容很长,则只能显示一个屏幕多一点,其它的都显示不出来,怎么办?
[对上面对解决]
用table+iframe试验一下
[对上面的质疑]
但是如何让iframe高度自动增长而不出现滚动条?
[对上面对解决]
<iframe src="d.htm" id="dd"></iframe>
在d.htm里:
<body onload="parent.window.document.all.dd.height=document.body.scrollHeight" topmargin="0">
在d.htm里:
<body onload="parent.window.document.all.dd.height=document.body.scrollHeight" topmargin="0">
[对上面的质疑]
这样的话菜单的target就没有办法指定了
[最终解决方案]
原来只要在服务器端调用
Menu1.Items[i].Selected = true;
就可以了,我绕着这么大个弯子,晕死
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 地球OL攻略 —— 某应届生求职总结
· 提示词工程——AI应用必不可少的技术
· Open-Sora 2.0 重磅开源!
· 周边上新:园子的第一款马克杯温暖上架