以下我问题重现,我已从ms得到证实这是TreeView的一个bug,我需要一个解决方法。
-------------
1. 新建一个页面
2. 拖一个新的TreeView到页面上,然后添加一些TreeNodes,将这些TreeNode的CheckBox打开。添加一个Asp.net Button 控件,及其一个Html Button,使用如下代码(假设我们对Index为"1.0"这个TreeNode进行测试)<%@ Page language="c#" Codebehind="WebForm3.aspx.cs" AutoEventWireup="false" Inherits="aspnettest.WebForm3" %>
<%@ Register TagPrefix="iewc" Namespace="Microsoft.Web.UI.WebControls" Assembly="Microsoft.Web.UI.WebControls" %>
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN" >
<HTML>
<HEAD>
<title>WebForm3</title>
<meta name="GENERATOR" Content="Microsoft Visual Studio .NET 7.1">
<meta name="CODE_LANGUAGE" Content="C#">
<meta name="vs_defaultClientScript" content="JavaScript">
<meta name="vs_targetSchema" content="http://schemas.microsoft.com/intellisense/ie5">
<script language=javascript >
function testfunc()
{
var tree=document.getElementById("TreeView1");
var checked=tree.getTreeNode("1.0").getAttribute("checked");
alert(checked);
}
</script>
</HEAD>
<body MS_POSITIONING="GridLayout">
<form id="Form1" method="post" runat="server">
<FONT face="宋体">
<iewc:TreeView id="TreeView1" style="Z-INDEX: 101; LEFT: 260px; POSITION: absolute; TOP: 28px"
runat="server" Width="271px" Height="279px">
<iewc:TreeNode Text="Node0"></iewc:TreeNode>
<iewc:TreeNode CheckBox="True" Text="Node1">
<iewc:TreeNode CheckBox="True" Text="Node4">
<iewc:TreeNode CheckBox="True" Text="Node5"></iewc:TreeNode>
</iewc:TreeNode>
</iewc:TreeNode>
<iewc:TreeNode Text="Node2"></iewc:TreeNode>
</iewc:TreeView><INPUT style="Z-INDEX: 102; LEFT: 648px; WIDTH: 48px; POSITION: absolute; TOP: 96px; HEIGHT: 64px"
type="button" value="Button" onclick="testfunc()">
<asp:Button id="Button1" style="Z-INDEX: 103; LEFT: 616px; POSITION: absolute; TOP: 280px" runat="server"
Width="64px" Height="48px" Text="Button"></asp:Button></FONT>
</form>
</body>
</HTML>3. 我们选中TreeNode的CheckBox,然后点击Server Button,然后Uncheck "1.0"TreeNode的CheckBox,我们点击Html Button,我们会发现,"1.0"TreeNode的“checked”状态属性与它实际的状态并不一致。
-------------
1. 新建一个页面
2. 拖一个新的TreeView到页面上,然后添加一些TreeNodes,将这些TreeNode的CheckBox打开。添加一个Asp.net Button 控件,及其一个Html Button,使用如下代码(假设我们对Index为"1.0"这个TreeNode进行测试)<%@ Page language="c#" Codebehind="WebForm3.aspx.cs" AutoEventWireup="false" Inherits="aspnettest.WebForm3" %>
<%@ Register TagPrefix="iewc" Namespace="Microsoft.Web.UI.WebControls" Assembly="Microsoft.Web.UI.WebControls" %>
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN" >
<HTML>
<HEAD>
<title>WebForm3</title>
<meta name="GENERATOR" Content="Microsoft Visual Studio .NET 7.1">
<meta name="CODE_LANGUAGE" Content="C#">
<meta name="vs_defaultClientScript" content="JavaScript">
<meta name="vs_targetSchema" content="http://schemas.microsoft.com/intellisense/ie5">
<script language=javascript >
function testfunc()
{
var tree=document.getElementById("TreeView1");
var checked=tree.getTreeNode("1.0").getAttribute("checked");
alert(checked);
}
</script>
</HEAD>
<body MS_POSITIONING="GridLayout">
<form id="Form1" method="post" runat="server">
<FONT face="宋体">
<iewc:TreeView id="TreeView1" style="Z-INDEX: 101; LEFT: 260px; POSITION: absolute; TOP: 28px"
runat="server" Width="271px" Height="279px">
<iewc:TreeNode Text="Node0"></iewc:TreeNode>
<iewc:TreeNode CheckBox="True" Text="Node1">
<iewc:TreeNode CheckBox="True" Text="Node4">
<iewc:TreeNode CheckBox="True" Text="Node5"></iewc:TreeNode>
</iewc:TreeNode>
</iewc:TreeNode>
<iewc:TreeNode Text="Node2"></iewc:TreeNode>
</iewc:TreeView><INPUT style="Z-INDEX: 102; LEFT: 648px; WIDTH: 48px; POSITION: absolute; TOP: 96px; HEIGHT: 64px"
type="button" value="Button" onclick="testfunc()">
<asp:Button id="Button1" style="Z-INDEX: 103; LEFT: 616px; POSITION: absolute; TOP: 280px" runat="server"
Width="64px" Height="48px" Text="Button"></asp:Button></FONT>
</form>
</body>
</HTML>3. 我们选中TreeNode的CheckBox,然后点击Server Button,然后Uncheck "1.0"TreeNode的CheckBox,我们点击Html Button,我们会发现,"1.0"TreeNode的“checked”状态属性与它实际的状态并不一致。
解决方案 »
- VS2005 VS2008怎么去开发windows Mobile ?
- reflector反编译函数为空时怎么回事?
- Web.Config配置问题
- Ajax中的时间设置问题
- 【北京】招聘asp.net开发人员
- 困惑已久的问题:怎样实现这样一个报表?
- 如何解决刷新的时候时间不重新倒记时的问题
- 请高手提供一个 "验收报告申请" 的样本
- 已经看过Microsoft.CSharp.CSharpCodeProvider 类, 也看过一下它的属性啊, 方法之类的, 但是不知道这个类有什么实用的东西可以应用?
- 程序需哟阿大量的报表,还有大部分的图象报表,使用.NET和使用JAVA哪个更好点?
- 有没有花生壳的高手啊!?可以上传文件却不可以访问!大家都急啊!!!大家都急啊!!!
- DataList数据绑定
具体怎么做啊,我都是在客户端操作的
点击Server Button时 把隐藏控件的直放入Session Session("Check") = hidden.value
http://msdn.microsoft.com/downloads/samples/internet/ASP_DOT_NET_ServerControls/WebControls/default.asp
下载后是后缀为bat的版本
(1)bulid.将bulid.bat的路径指向csc.exe所在路径,生成Microsoft.Web.UI.WebControls.dll。
(2)在wwwroot下创建空目录webctrl_client\1_0。
(3)将build\Runtime下的文件拷至webctrl_client\1_0下。
(4)选择工具箱的自定义工具箱,添加Microsoft.Web.UI.WebControls.dll。
有些麻烦
但如果你能找到后缀是msi的自动安装版本,直接下一步就行(我一直用这个版本,hoho)
安装后,通过“自定义工具箱”->“.net框架组件”把TreeView添加到工具箱里2.运行时无法显示
一般是TreeView的版本问题,最好下载英文版自动安装版本重新安装,安装前应该先到添加删除程序里卸掉原版本3.显示格式出错(非树状显示)
TreeView要求客户端浏览器版本为IE5.5及以上,最好要求客户端升级为IE6.04.框架里使用TreeView
设置NavigateUrl、Target属性,可更新另外的Frame5.找不到TreeNode类
使用TreeView,最好添加namespace:using Microsoft.Web.UI.WebControls;6.遍历TreeView节点(递归算法)
private void Page_Load(object sender, System.EventArgs e)
{
GetAllNodeText(TreeView1.Nodes);
}
void GetAllNodeText(TreeNodeCollection tnc)
{
foreach(TreeNode node in tnc)
{
if(node.Nodes.Count!=0)
GetAllNodeText(node.Nodes);
Response.Write(node.Text + " ");
}
}7.得到node结点的父节点
TreeNode pnode;
if(node.Parent is TreeNode)
pnode=(TreeNode)node.Parent;
else
//node is root node8.修改TreeView样式(示例)
<iewc:TreeView id="TreeView1" runat="server" HoverStyle="color:blue;background:#00ffCC;" DefaultStyle="background:red;color:yellow;" SelectedStyle="color:red;background:#00ff00;">
用代码:
TreeView1.DefaultStyle["font-size"] = "20pt";9.展开时不提交,改变选择节点时才提交
将autopostback设置成false;
在body里添加 <body onload="initTree()">
然后在PageLoad里写:
string strTreeName = "TreeView1";
string strRef = Page.GetPostBackEventReference(TreeView1);
string strScript = "<script language=\"JavaScript\"> \n" + "<!-- \n" + " function initTree() { \n" +" " + strTreeName + ".onSelectedIndexChange = function() { \n" + "if (event.oldTreeNodeIndex !=
event.newTreeNodeIndex) \n" + "this.queueEvent('onselectedindexchange', event.oldTreeNodeIndex + ',' + event.newTreeNodeIndex); \n" + "window.setTimeout('" + strRef.Replace("'","file://'/") + "', 0, 'JavaScript'); \n" + " } \n" + " } \n" + "// --> \n" + "</script>";
Page.RegisterClientScriptBlock("InitTree",strScript );
这样就只有你点击的节点更改的时候才提交!10.TreeView结合XML
把XML文件设置为如下格式,然后直接设置TreeNodeSrc为该XML文件就行
<?xml version="1.0" encoding="GB2312"?>
<TREENODES>
<TREENODE TEXT="node0" EXPANDED="true">
<TREENODE TEXT="node1"/>
<TREENODE TEXT="node2"/>
</TREENODE>
<TREENODE TEXT="node3" NavigateURL="3.aspx"/>
</TREENODES>
或者用代码
TreeView1.TreeNodeSrc="a.xml";
TreeView1.DataBind(); 客户端控制TreeView
http://expert.csdn.net/Expert/topic/1382/1382892.xml1.设置所选节点,如选中第二个节点
function SetSelNode()
{
TreeView1.selectedNodeIndex="1";
}2.得到所选节点的Text,ID或NodeData
function GetAttribute()
{
alert(TreeView1.getTreeNode(TreeView1.selectedNodeIndex).getAttribute("Text"));
}
替换Text为ID或NodeData,可分别得到所选节点的ID或NodeData3.修改节点属性,如修改第一个节点的Text
function ModifyNode()
{
var node=TreeView1.getTreeNode("0");
node.setAttribute("Text","hgknight");
}4.得到点击节点
function TreeView1.onclick()
{
alert(TreeView1.getTreeNode(TreeView1.clickedNodeIndex).getAttribute("Text"));
}5.添加节点
function AddNode()
{
var node=TreeView1.createTreeNode();
node.setAttribute("Text","hgknight");
TreeView1.add(node);
}6.js遍历所有节点
var AllRootNode=new Array();
AllRootNode=TreeView1.getChildren();
AlertNode(AllRootNode); function AlertNode(NodeArray)
{
if(parseInt(NodeArray.length)==0)
return;
else
{
for(i=0;i<NodeArray.length;i++)
{
var cNode;
cNode=NodeArray[i];
alert(cNode.getAttribute("Text"));
if(parseInt(cNode.getChildren().length)!=0)
AlertNode(cNode.getChildren());
}
}
}