我在窗口中托管了一个wpf页面。但是当我试图使用它时,我得到Null异常。 它工作,然后我在另一种方法中使用此代码,但不是在alla方法中为什么会这样? 请建议。
NewPage page = new NewPage ();
Window w = Window.GetWindow(this.Parent);
w.Content = page;
编辑:
下面是完整的代码:
public HandOverListPage() {
InitializeComponent();
_settings = new Settings();
}
public void ShowCurrentInUseAssignment() {
_currentDoc = (App.Current as App).SelectedHandOverDoc;
var r = from item in (App.Current as App).SelectedHandOverDoc.Items
where item.Status != 20
select item;
if(r.Count() == 0) {
//Report assignment to QP with status finished
ReportAssignment();
HandOverPage page = new HandOverPage();
Window w = Window.GetWindow(this.Parent);
w.Content = page;
return;
} else {
ICollectionView view = CollectionViewSource.GetDefaultView((App.Current as App).SelectedHandOverDoc.Items);
view.SortDescriptions.Add(new SortDescription("Status", ListSortDirection.Ascending));
ListBoxAssignmentItems.ItemsSource = view;
}
TxtBlockCounter.Text = r.Count().ToString();
}
错误:
{“值不能为空。\ r \ nParameter name:dependencyObject”}
我在使用即时窗口
时得到这个 ?this.GetType()
{Name = "HandOverListPage" FullName = "QP_Truck.Pages.HandOverListPage"}
[System.RuntimeType]: {Name = "HandOverListPage" FullName = "QP_Truck.Pages.HandOverListPage"}
base {System.Reflection.MemberInfo}: {Name = "HandOverListPage" FullName = "QP_Truck.Pages.HandOverListPage"}
Assembly: {QP Truck, Version=1.0.0.0, Culture=neutral, PublicKeyToken=null}
AssemblyQualifiedName: "QP_Truck.Pages.HandOverListPage, QP Truck, Version=1.0.0.0, Culture=neutral, PublicKeyToken=null"
Attributes: Public | BeforeFieldInit
BaseType: {Name = "Page" FullName = "System.Windows.Controls.Page"}
ContainsGenericParameters: false
DeclaringMethod: 'this.GetType().DeclaringMethod' threw an exception of type 'System.InvalidOperationException'
DeclaringType: null
FullName: "QP_Truck.Pages.HandOverListPage"
GenericParameterAttributes: 'this.GetType().GenericParameterAttributes' threw an exception of type 'System.InvalidOperationException'
GenericParameterPosition: 'this.GetType().GenericParameterPosition' threw an exception of type 'System.InvalidOperationException'
GUID: {93eb30b9-a64e-3c6b-9182-0f93582d188d}
HasElementType: false
IsAbstract: false
IsAnsiClass: true
IsArray: false
IsAutoClass: false
IsAutoLayout: true
IsByRef: false
IsClass: true
IsCOMObject: false
IsContextful: false
IsEnum: false
IsExplicitLayout: false
IsGenericParameter: false
IsGenericType: false
IsGenericTypeDefinition: false
IsImport: false
IsInterface: false
IsLayoutSequential: false
IsMarshalByRef: false
IsNested: false
IsNestedAssembly: false
IsNestedFamANDAssem: false
IsNestedFamily: false
IsNestedFamORAssem: false
IsNestedPrivate: false
IsNestedPublic: false
IsNotPublic: false
IsPointer: false
IsPrimitive: false
IsPublic: true
IsSealed: false
IsSerializable: false
IsSpecialName: false
IsUnicodeClass: false
IsValueType: false
IsVisible: true
MemberType: TypeInfo
Module: {QP Truck.exe}
Namespace: "QP_Truck.Pages"
ReflectedType: null
StructLayoutAttribute: {System.Runtime.InteropServices.StructLayoutAttribute}
TypeHandle: {System.RuntimeTypeHandle}
TypeInitializer: null
UnderlyingSystemType: {Name = "HandOverListPage" FullName = "QP_Truck.Pages.HandOverListPage"}
答案 0 :(得分:11)
您在构造函数方法中发布的代码是什么?
UserControl
的父级在其构造函数中始终为null,因此this.Parent
返回空引用。因此,调用Window.GetWindow(this.Parent)
会引发ArgumentNullException
,因为您指定的依赖项对象尚未创建。
要解决此问题,您需要将代码放在Initialized
事件处理程序中。引发此事件时,您可以确保已创建UserControl
。
答案 1 :(得分:5)
尝试所有者属性 你必须分配它。
样品:
public Activity ShowLookUp(Window owner) { ActivityLookUp lookup = new ActivityLookUp(); lookup.Owner = owner; lookup.ShowDialog(); }
答案 2 :(得分:0)
致电this.Parent
时,您的上下文是什么?您希望this
成为page
对象的引用吗?从您添加的代码示例中,情况并非如此。我建议你在Window.GetWindow
行放置一个断点,并在即时窗口中?this.GetType()
查看发生了什么。
答案 3 :(得分:0)
标签有时很有用。
为什么不尝试这个。
// "this" is your Window
YourFrame.Content = new YourPage() { Tag = this };
并在你的网页上试试这个
Window w = (Window)this.Tag;
// and do all the Window wonders
:)
答案 4 :(得分:0)
虽然列出了可接受的答案,但它们似乎都使问题复杂化。
页面没有父页面,但由于页面只是一个页面,而不是一个窗口调用获取窗口本身将返回窗口引用而不是页面,因此您只需要;
Window w = Window.GetWindow(this);
简单地省略.Parent
答案 5 :(得分:0)
您可以使用不同的选项:
从子用户控件背后的代码
但是如果在构造函数中调用它们,它们都会返回 null,因为子项的初始化发生在将控件附加到可视化树之前。
因此您必须在子用户控件完成加载后调用它们。
public MyChildUserControl()
{
InitializeComponent();
//Postponing the retrieval of the parent using the OnLoaded event
Loaded += (s, e) =>
{
var p = VisualTreeHelper.GetParent(this);
while (!(ucParent is UserControl))
{
ucParent = LogicalTreeHelper.GetParent((DependencyObject) this);
}
_parentWindow = Window.GetWindow(this);
/// whatever you are going to do with parent window
};
}