0

在下面的第一个块中,我故意错过了命名我的一个绑定语句,因此我可以与我的第二个块进行比较。不同之处在于在“ag2.item ...”行上找不到属性。
项目是我的模型。

在块 2 中,您可以看到它指向我的视图模型 (ag2.viewModel.itemViewModel)。

我需要在我的 XAML 或代码隐藏中做什么才能让它指向我的类而不是视图模型?

区块 1:

BindingExpression 路径错误:在 'ag2.item、ag2、Version=1.0.0.0、Culture=neutral、PublicKeyToken=null' 上找不到 'itemModel1' 属性。BindingExpression: Path='itemModel1' DataItem='ag2.item , ag2, Version=1.0.0.0, Culture=neutral, PublicKeyToken=null'; 目标元素是'Windows.UI.Xaml.Controls.TextBlock'(名称='null');目标属性是“文本”(类型“字符串”)

区块 2:

BindingExpression 路径错误:在 'ag2.viewModel.itemViewModel、ag2、Version=1.0.0.0、Culture=neutral、PublicKeyToken=null' 上找不到 'itemModel' 属性。BindingExpression: Path='itemModel' DataItem='ag2.viewModel.itemViewModel, ag2, Version=1.0.0.0, Culture=neutral, PublicKeyToken=null'; 目标元素是'Windows.UI.Xaml.Controls.TextBlock'(名称='null');目标属性是“源”(类型“字符串”)

块 2 后面的代码:

    itemViewModel VM = new itemViewModel((Int32)navigationParameter);
    DataContext = VM;

我还应该注意,在第 1 块中,我正在绑定到设置 的 GridView ItemSource="{Binding item}"

在块 2 中,我使用网格和文本块构建了我的 UI:Text="{Binding Path=itemModel}"

更新:试图获得更好的理解。我把我的代码放在那里:这是 XAML,下面是 ViewModel,下面是我的模型……我是 MVVM 的新手,所以我真的不知道我做错了什么。任何帮助是极大的赞赏。

XAML:

<common:LayoutAwarePage
    x:Name="pageRoot"
    x:Class="autoGarage2.VehicleItemDetailPage"
    IsTabStop="false"
    xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
    xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
    xmlns:common="using:autoGarage2.Common"
    xmlns:local="using:autoGarage2"
    xmlns:data="using:autoGarage2"
    xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
    xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006">


    <!--
        This grid acts as a root panel for the page that defines two rows:
        * Row 0 contains the back button and page title
        * Row 1 contains the rest of the page layout
    -->
    <Grid Style="{StaticResource LayoutRootStyle}">

        <Grid.RowDefinitions>
            <RowDefinition Height="140"/>
            <RowDefinition Height="2*"/>
        </Grid.RowDefinitions>

        <!-- Back button and page title -->
        <Grid
         Style="{StaticResource LayoutRootStyle}" Grid.Row="0">

            <Grid.ColumnDefinitions>
                <ColumnDefinition Width="Auto"/>
                <ColumnDefinition Width="*"/>
            </Grid.ColumnDefinitions>
            <Button x:Name="backButton" Click="GoBack" IsEnabled="{Binding Frame.CanGoBack, ElementName=pageRoot}" Style="{StaticResource BackButtonStyle}"/>
            <TextBlock x:Name="pageTitle" Text="{StaticResource AppName}" Style="{StaticResource PageHeaderTextStyle}" Grid.Column="1"/>
        </Grid>



        <Grid Grid.Row="1">


            <Grid.ColumnDefinitions>
               <ColumnDefinition Width="Auto"/> 
                <ColumnDefinition Width="*"/>
            </Grid.ColumnDefinitions>
            <Grid.RowDefinitions>
                <RowDefinition Height="3*"/>
                <RowDefinition Height="1*"/>
            </Grid.RowDefinitions>


                <StackPanel Grid.Row="0" Orientation="Horizontal" Width="auto" Margin="50,0,0,0" VerticalAlignment="Top"  >
                    <Grid HorizontalAlignment="Left" Width="250" Height="250">
                        <Border Background="White" BorderBrush="CornflowerBlue" BorderThickness="1">
                                <Image Source="{Binding Image}" Margin="50"/>
                            </Border>
                            <StackPanel VerticalAlignment="Bottom" Background="CornflowerBlue">
                                <StackPanel Orientation="Horizontal" DataContext="{Binding vehicles}">
                                <TextBlock Text="{Binding VehicleMake}" Foreground="{StaticResource ListViewItemOverlayForegroundThemeBrush}" Style="{StaticResource PageSubheaderTextStyle}" Margin="5"/>
                                <TextBlock Text="{Binding VehicleModel}" Foreground="{StaticResource ListViewItemOverlaySecondaryForegroundThemeBrush}" Style="{StaticResource PageSubheaderTextStyle}" Margin="5"/>
                                </StackPanel>
                            </StackPanel>
                        </Grid>
                </StackPanel>
                    <StackPanel Grid.Row="0" Grid.Column="1">
                        <Grid Margin="20,0,0,20">
                            <Grid.RowDefinitions>
                                <RowDefinition Height="1*"/>
                                <RowDefinition Height="1*"/>
                                <RowDefinition Height="1*"/>
                                <RowDefinition Height="1*"/>                                
                                <RowDefinition Height="1*"/>                                
                                <RowDefinition Height="1*"/>
                                <RowDefinition Height="1*"/>
                                <RowDefinition Height="1*"/>
                                <RowDefinition Height="1*"/>                                
                                <RowDefinition Height="1*"/>    
                                <RowDefinition Height="1*"/> 
                                <RowDefinition Height="1*"/> 
                                <RowDefinition/>                                
                            </Grid.RowDefinitions>

                            <Grid.ColumnDefinitions>
                                <ColumnDefinition Width="1*"/>
                                <ColumnDefinition Width="1*"/>
                                <ColumnDefinition Width="2*"/>
                            </Grid.ColumnDefinitions>






                            <TextBlock Text="Vehicle Make:" Grid.Row="0" Grid.Column="0" FontSize="25" Foreground="Black" />
                            <TextBox Text="{Binding Path=VehicleMake}"  Grid.Row="0" Grid.Column="1" FontSize="25" BorderBrush="CornflowerBlue" BorderThickness="1"/>

                            <TextBlock Text="Vehicle Model:" FontSize="25" Foreground="Black" Grid.Row="1" Grid.Column="0"/>
                            <TextBox Text="{Binding VehicleModel}"  Grid.Row="1" Grid.Column="1" FontSize="25" BorderBrush="CornflowerBlue" BorderThickness="1"/>                            

                            <TextBlock Text="Vehicle Year:" FontSize="25" Foreground="Black" Grid.Row="2" Grid.Column="0"/>
                            <TextBox Text="{Binding VehicleYear}"  Grid.Row="2" Grid.Column="1" FontSize="25" BorderBrush="CornflowerBlue" BorderThickness="1"/>

                            <TextBlock Text="License Plate:" FontSize="25" Foreground="Black" Grid.Row="3" Grid.Column="0"/>
                            <TextBox Text=""  Grid.Row="3" Grid.Column="1" FontSize="25" BorderBrush="CornflowerBlue" BorderThickness="1"/> 

                            <TextBlock Text="VIN #" FontSize="25" Foreground="Black" Grid.Row="4" Grid.Column="0"/>
                            <TextBox Text=""  Grid.Row="4" Grid.Column="1" FontSize="25" BorderBrush="CornflowerBlue" BorderThickness="1" />    

                            <TextBlock Text=" Current Mi/Km" FontSize="25" Foreground="Black" Grid.Row="5" Grid.Column="0"/>
                            <TextBox Text=""  Grid.Row="5" Grid.Column="1" FontSize="25" BorderBrush="CornflowerBlue" BorderThickness="1"/>              

                            <TextBlock Text="" FontSize="25" Foreground="Black" Grid.Row="6" Grid.ColumnSpan="2"/>

                            <TextBlock Text="Last Oil Change" FontSize="25" Foreground="Black" Grid.Row="7" Grid.Column="0"/>
                            <TextBox Text=""  Grid.Row="7" Grid.Column="1" FontSize="25" BorderBrush="CornflowerBlue" BorderThickness="1"/>              

                            <TextBlock Text="Last Oil Change Mi/Km" FontSize="25" Foreground="Black" Grid.Row="8" Grid.Column="0"/>
                            <TextBox Text=""  Grid.Row="8" Grid.Column="1" FontSize="25" BorderBrush="CornflowerBlue" BorderThickness="1"/>

                            <TextBlock Text="" FontSize="25" Foreground="Black" Grid.Row="9" Grid.ColumnSpan="2"/>

                            <TextBlock Text="Reminder Mi/Km" FontSize="25" Foreground="Black" Grid.Row="10" Grid.Column="0"/>
                            <TextBox Text=""  Grid.Row="10" Grid.Column="1" FontSize="25" BorderBrush="CornflowerBlue" BorderThickness="1"/>     

                            <TextBlock Text="Reminder Month(s)" FontSize="25" Foreground="Black" Grid.Row="11" Grid.Column="0"/>
                            <TextBox Text=""  Grid.Row="11" Grid.Column="1" FontSize="25" BorderBrush="CornflowerBlue" BorderThickness="1"/>                          

                        </Grid>                     
                </StackPanel>

            </Grid>

    </Grid>
</common:LayoutAwarePage>

查看型号:

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Collections.ObjectModel;
using Windows.Foundation.Collections;
using System.IO;


namespace autoGarage2.viewModel
{
    class vehicleViewModel
    {
        private IList<vehicle> m_vehicles;
        private IList<vehicle> m_vehicleItem;

        public IList<vehicle> vehicles
        {
            get { return m_vehicles; }
            set { m_vehicles = value; }
        }

        public IList<vehicle> vehicleItem
        {
            get { return m_vehicleItem; }
            set { m_vehicleItem = value; }
        }

        private IList<vehicle> getVehicleDetail(Int32 vId)
        {
            var vehicleItem =
                from v in vehicles
                where v.VehicleId == vId
                select v;
            if (vId > 0)
            {
                //vehicles.Clear();
                m_vehicles = new List<vehicle>();
                foreach (var item in vehicleItem)
                {
                    m_vehicles = new List<vehicle>
                    {
                        new vehicle(item.VehicleId, item.VehicleMake.ToString(), item.VehicleModel.ToString(), item.VehicleYear, item.Image.ToString())
                    };
                    //vehicle myVehicle = new vehicle(item.VehicleId, item.VehicleMake.ToString(), item.VehicleModel.ToString(), item.VehicleYear, item.Image.ToString());
                    //m_vehicles.Add(myVehicle);
                }

            }

            return m_vehicles;
        }

        public vehicleViewModel(Int32 vId)
        {
                m_vehicles = new List<vehicle>
                {        
                new vehicle(1, "Mazda", "3", 2011, "Assets/car2.png"),
                new vehicle(2, "Chevy", "Tahoe", 2004, "Assets/jeep1.png"),
                new vehicle(3, "Honda", "Goldwing", 2007 ,"Assets/moto1.png")
                };

                if (vId > 0)
                {
                    //m_vehicles = new List<vehicle>();
                    //m_vehicles = 
                    //getVehicleDetail(vId);
                    m_vehicles = new List<vehicle>
                    {        
                    new vehicle(2, "Chevy", "Tahoe", 2004, "Assets/jeep1.png"),
                    };

                }
        }



        #region dbCode

        //string dbName = "vehicle.db";


        //var dbPath = Path.Combine(Windows.Storage.ApplicationData.Current.LocalFolder.Path, dbName);    
        //using (var db = new SQLite.SQLiteConnection(dbPath))    
        //    {
        //        var list = db.Table<vehicle>().ToList();
        //        m_vehicles = new List<vehicle>();
        //        for (Int32 i = 0; i < list.Count; i++)
        //        {
        //            //m_vehicles.Add(db.Table<vehicle>().ToList());
        //        }
        //    }




        //foreach (vehicle item in m_vehicles)
        //{
        //    AllItems.Add(item);
        //}      
        #endregion

    }
}

模型:

using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
//using SQLite;
using Windows.UI.Xaml.Media;
using Windows.UI.Xaml.Media.Imaging;

namespace autoGarage2
{
    class vehicle : autoGarage2.Common.BindableBase
    {
        public vehicle()
        { 
        }

        public vehicle(string imagePath)
        {
            this._imagePath = imagePath;
        }
        public vehicle(Int32 vId, string vMake, string vModel, Int16 vYear, string imagePath)
        {
            this.m_vehicleID = vId;
            this.m_vehicleMake = vMake;
            this.m_vehicleModel = vModel;
            this.m_vehicleYear = vYear;
            this.m_vehicleName = vMake + " " + vModel;
            this._imagePath = imagePath;
        }


        private Int32 m_vehicleID;

        private String m_vehicleMake;
        private String m_vehicleModel;
        private Int16 m_vehicleYear;
        private string m_vehicleName;


        private ImageSource _image = null;
        private String _imagePath = null;
        private static Uri _baseUri = new Uri("ms-appx:///");

        //[AutoIncrement, PrimaryKey]
        public Int32 VehicleId
        {
            get
            {
                return m_vehicleID;
            }
            set
            {
                m_vehicleID = value;
                OnPropertyChanged("VehicleId");
            }
        }

        public String VehicleMake
        {
            get
            {
                return m_vehicleMake;
            }
            set
            {
                m_vehicleMake = value;
                OnPropertyChanged("VehicleMake");
            }
        }

        public String VehicleModel
        {
            get
            {
                return m_vehicleModel;
            }
            set
            {
                m_vehicleModel = value;
                OnPropertyChanged("VehicleModel");
            }
        }
    public Int16 VehicleYear
    {
        get
        {
            return m_vehicleYear;
        }
        set
        {
            m_vehicleYear = value;
            OnPropertyChanged("VehicleYear");
        }
    }

    public string VehicleName
    {
        get
        {
            return m_vehicleName;
        }
        set
        {
            m_vehicleName = value;
            OnPropertyChanged("VehicleName");
        }
    }

    public ImageSource Image
    {
        get
        {
            if (this._image == null && this._imagePath != null)
            {
                this._image = new BitmapImage(new Uri(vehicle._baseUri, this._imagePath));
            }
            return this._image;
        }

        set
        {
            this._imagePath = null;
            this.SetProperty(ref this._image, value);
        }
    }

    public void SetImage(String path)
    {
        this._image = null;
        this._imagePath = path;
        this.OnPropertyChanged("Image");
    }
}

}

4

3 回答 3

1

您似乎正在尝试绑定到列表,但您没有在 XAML 中使用任何 ItemsControl。您可能应该使用 ListView 之类的东西,将其ItemsSource绑定到您的车辆或 vehicleItem 列表,使用 ItemTemplate/DataTemplate 来定义集合中每个项目的外观,如果您的集合发生更改,请使用 ObservableCollection,或者如果您交换,则引发 INotifyPropertyChanged.PropertyChanged 通知出您的收藏等。否则我建议阅读有关绑定ItemsControls的内容或有关 XAML 的一般书籍,例如 Adam Nathan 的WPF Unleashed. 似乎您正在设置 m_vehicles 只是为了在下一条语句中将其替换为新的。另外 - 您正在将 StackPanel 的 DataContext 设置为您的列表,这是允许的,但它不起作用,因为 StackPanel 元素的 DataContext 仍然是整个列表而不是它的项目,这就是您得到的使用 ItemsControl。

于 2012-08-26T04:23:41.643 回答
1

听起来您正在尝试将您的数据绑定TextBlock到不同的对象,而不是 ViewModel(这是DataContext您的窗口/控件的)。如果这是正确的,您需要将DataContextTextBlock父级Grid设置为您想要 DataBind 到的对象。

DataContext用于确定控件的 DataBind 到的路径,并沿可视树继承。因此,如果您DataContext设置为 MyViewModel,并且您使用Text="{Binding Path=itemModel}",您的绑定路径将为MyViewModel.itemModel.

如果您不想包含MyViewModel在绑定路径中,则需要更改相关DataContext控件或包含控件的 。对于 MVVM,这通常是通过将另一个对象公开为 ViewModel 的属性来完成的。因此,如果您的 MyViewModel 有一个属性 ItemModel:

public class ItemModel
{
    public string Property1 { get; }
    public string Property2 { get; }
}

public class MyViewModel
{
    public ItemModel ItemModel { get; private set; }
}

然后您的 XAML 可能看起来像这样(假设 MyViewModel 是父窗口/控件的 DataContext)。

<Grid Grid.Row="1" DataContext="{Binding ItemModel}">
    <Grid.RowDefinitions>
        <RowDefinition/>
        <RowDefinition/>
    </Grid.RowDefinitions>
    <TextBlock Text="{Binding property1}"/>
    <TextBlock Text="{Binding Property2}" Grid.Row="1"/>
</Grid>

并且这两个文本框将绑定到 ItemModel 对象的 Property1 和 Property2。

于 2012-08-25T17:08:28.980 回答
0

在一个周末不看它之后,我能够让我的数据显示出来。基本上我注意到我收到一个绑定错误,指出它在我的 autoGarage2.vehicles 列表中找不到该属性。因此,对于咧嘴一笑,我以这样的方式对绑定进行了开头:

{Binding vehicles[0].vehicleModel}

下次我运行它时,数据就在那里。在考虑了更多之后,我决定创建一个车辆对象,而不是填充列表对象,我只填充单个车辆属性。现在我正在做这样的事情:

{Binding vehicleSingle.vehicleModel}

感谢大家的帮助。我想这只是 MVVM 在 XAML 中工作方式的细微差别......

于 2012-08-28T11:56:02.953 回答