zoukankan
html css js c++ java
IPostBackDataHandler实现CollapablePanel控件的状态保持
在CollapablePanel控件的设计过程中,遇到了这样一个问题:当某一项面板展开时,执行页面后,控件中面板的状态将恢复到原先的状态,这样是不是特感到郁闷。
查了一下MSDN,从中知道了可以通过实现IPostBackDataHandler来实现。
下面分别给出实现代码:
1、在Page_Init将控件注册为需要回发处理的控件。
protected
override
void
OnInit(EventArgs e)
{
base
.OnInit(e);
//
遍列每一个CoolPanel,初始其状态
foreach
(CollPanel p
in
m_Panels)
{
p.i_Expanded
=
m_ExpandSolePanel
?
false
: p.Expanded;
}
if
(m_ExpandSolePanel)
{
m_Panels[
0
].i_Expanded
=
true
;
}
//
注册控件
if
(Page
!=
null
)
{
Page.RegisterRequiresPostBack(
this
);
}
}
2、在OnPreRender中注册一个HtmlInputHidden控件,并将子面板集合的状态写入。
protected
override
void
OnPreRender(EventArgs e)
{
base
.OnPreRender(e);
string
s
=
""
;
foreach
(CollPanel p
in
m_Panels)
{
s
+=
(p.i_Expanded.ToString()
==
"
True
"
?
"
1
"
:
"
0
"
)
+
"
,
"
;
}
if
(Page
!=
null
)
{
Page.RegisterHiddenField(
this
.ClientID
+
"
_state
"
, s);
}
}
3、最后,通过LoadPostData从客户端获得状态
public
bool
LoadPostData(String postDataKey, NameValueCollection values)
{
//
从客户端获得每个Panel的状态
string
value
=
values[
this
.ClientID
+
"
_state
"
];
if
(value
!=
null
)
{
string
[] s
=
value.Split(
'
,
'
);
for
(
int
i
=
0
; i
<
m_Panels.Count; i
++
)
{
m_Panels[i].i_Expanded
=
s[i]
==
"
1
"
?
true
:
false
;
}
}
return
false
;
}
[ 完 ]
呵呵,是不是很简单哦!!
查看全文
相关阅读:
javascript 之迭代器
前端数据结构--二叉树先序、中序、后序 递归、非递归遍历
前端数据结构--树
前端数据结构--散列表(哈希表)
前端数据结构--线性结构-队列、栈
前端数据结构--线性结构-链表
前端数据结构--线性结构-数组
前端数据结构---复杂度分析
前端数据结构---相关基础概念
css整理之-----------基本知识
原文地址:https://www.cnblogs.com/faib/p/701637.html
最新文章
可变类与不可变类
转 JAVA – 虚函数、抽象函数、抽象类、接口
关于PLSQL登陆报出Not logged on问题
IE下iframe height="100%"无效的解决方法
设计模式:策略、代理、单例
JSTL标签库
JQuery: effect
JQuery: Slide Up/Down
网页中如何实现注册时表单检验(两次输入的密码是否相同)
BigDecimal精度问题
热门文章
Missing artifact com.oracle:ojdbc14:jar:10.2.0.3.0
MAVEN项目中include引入静态文件时报错找不到文件
tomcat启动项目时一直在跑,项目没起来
eclipse中出现An internal error occurred during: "Initializing Java Tooling"
关于Excel报错
mysql5.7.21下载及安装步骤
POI中excle样式怎么写
ORACLE中INSERT插入多条数据
关于Tomcat启动时,长时间停在Initializing Spring root webApplicationContext处的原因
前端---梳理 http 知识体系 1
Copyright © 2011-2022 走看看