Silverlight用户控件转移时产生的“元素已经是另一个元素的子元素”问题

简介:

        最近的项目中遇到了silverlight用户控件由一个canvas转移到另一个canvas的问题,在转移的过程中一直提示“元素已经是另一个元素的子元素”,十分讨厌,调试了多次也没有找到原因所在,情况如下

1,简单的移动

  

LayerTwo是一个usercontrol,mainpage.xaml上呢有两个canvas,其中一个放的有LayerTwo,

 代码

< Grid  x:Name ="LayoutRoot"  Background ="White" >  
        
< Canvas  Height ="100"  HorizontalAlignment ="Left"  Margin ="24,25,0,0"  Name ="canvas1"  VerticalAlignment ="Top"  Width ="200"   >  
             
< layer:LayerTwo  x:Name ="uc"  Canvas.Left ="3"  Canvas.Top ="-130" ></ layer:LayerTwo >  
        
</ Canvas >  
        
< Canvas  Height ="100"  HorizontalAlignment ="Left"  Margin ="24,140,0,0"  Name ="canvas2"  VerticalAlignment ="Top"  Width ="200"   />  
        
< Button  Content ="Button"  Height ="23"  HorizontalAlignment ="Left"  Margin ="266,117,0,0"  Name ="button1"  VerticalAlignment ="Top"  Width ="75"   />  
    
</ Grid >

  

我们如果将layertwo从canvas1中转移到canvas2中,只需要 

UserControl uc  =   this .canvas1.Children[ 0 as  UserControl; 
            
this .canvas1.Children.RemoveAt( 0 ); 
            
this .canvas2.Children.Add(uc);

 

2,如果usercontrol是放在嵌套的canvas中或者是其他的usercontrol中呢?

如果我们将上面的例子简单的改变一下,在canvas1中再增加一层canvas3,layerTwo.xaml放在canvas3中,如果想把layerone.xaml转移到canvas2中怎么做呢?

 

代码
Canvas c  =   this .canvas2.Children[ 0 as  Canvas; 
            UserControl uc 
=  c.Children[ 0 as  UserControl; 
            
this .canvas2.Children.RemoveAt( 0 ); 
            
this .canvas1.Children.Add(uc);

 

 这种做法就是直接将内层的canvas去掉,按说内层的canvas去掉后,里面的usercontrol应该也没有了,但是当我们添加获取的usercontrol到canvas1时,发现“元素已经是另一个元素的子元素”这个恼人的提示,debug后发现这个usercontrol居然还有parent父级对象,于是在usercontrol的最直接上级canvas3 再次执行了removeat的方法才得以通过。

 

 this.canvas2.Children.RemoveAt(0); 

//换成这样
c.Children.RemoveAt( 0 ); 

 

 类似的用户控件使用必须确保此用户控件的父级对象为空,执行remove此用户控件后再添加到其他地方,否则是添加不了的。




     本文转自wengyuli 51CTO博客,原文链接:http://blog.51cto.com/wengyuli/587187,如需转载请自行联系原作者






相关文章
一起谈.NET技术,Silverlight 游戏开发小技巧:扇形排列元素
  斗地主风靡了大江南北,在春晚都做免费性推广,棋牌游戏平台几乎将其作为标配,但是牌类游戏总是一成不变的样子——横向排列,如果扇形排列应该更加符合真实,最近在WP7上玩了一个UNO游戏就是用扇形排列,感觉很不错,今天咱们照猫画虎,在Silverlight上实现一个扇形的手牌效果。
919 0
Silverlight 游“.NET研究”戏开发小技巧:扇形排列元素
  斗地主风靡了大江南北,在春晚都做免费性推广,棋牌游戏平台几乎将其作为标配,但是牌类游戏总是一成不变的样子——横向排列,如果扇形排列应该更加符合真实,最近在WP7上玩了一个UNO游戏就是用扇形排列,感觉很不错,今天咱们照猫画虎,在Silverlight上实现一个扇形的手牌效果。
974 0