zoukankan      html  css  js  c++  java
  • WPF中后台存储数据方法一XML

    就我个人所得,目前用作WPF数据源的方法有如下几种:

    1.控件的互相绑定;

    2.XML存储数据;

    3.序列化反序列化json串存储;

    4.联系数据库;

    其中控件的相互绑定无非是binding方法,由于不能存储修改之后的操作,故在此不过多讨论;

    接下来说说XML方法存储数据;

    一、首先将数据存储在XML中

    1 <?xml version="1.0" encoding="utf-8" ?>
    2 <curriculum_info class_name = "高等数学" teacher = "吕良福" place ="24楼301室" time="31"></curriculum_info>

    例如一个名为curriculum_info的对象在courses.xml中;

    二、在XMAL中调用该对象中的数据

    在顶部(window下)需有如下代码:

     1     <Window.Resources>
     2         <XmlDataProvider x:Key="course-info" Source="courses.xml" XPath="/curriculum_info/*"></XmlDataProvider>
     3         <DataTemplate x:Key="showcourse">
     4             <TextBlock Text="{Binding XPath=class_name}"></TextBlock>
     5         </DataTemplate>
     6         <Style TargetType="{x:Type TextBlock}" >
     7             <Setter Property="FontStyle" Value="Italic" />
     8             <Setter Property="FontFamily" Value="Trebuchet MS" />
     9             <Setter Property="FontSize" Value="12" />
    10         </Style>
    11     </Window.Resources>
     
    对数据源的调用放在<Window.Resources>中。
      通过<XmlDataProvider>标记,实现对XML数据源的调用,x:Key是资源的引用的ID,Source是XML资源文件路径,XPath指出XML文件内部数据存放的路径。
     
    在<Window.Resources>还有另外两个标记,分别是DataTemplate和Style。
      DataTemplate中放置一个TextBlock用来,将TextBlock的Text属性与XML数据源中的class_name标记绑定,也就说用来显示XML文件中的class_name。
      Style是WPF的样式。在这里,我们指定了本Window中,所有的TextBlock都采用Style中定义的样式。
     
    接下来就可以实现绑定了:
    1 <TextBlock Grid.Column="1" Grid.Row="3">Course:<TextBlock DataContext="{Binding Source={StaticResource course-info}}" Text="{Binding XPath=class_name}" Width="26"/> </TextBlock>

    那么这个TextBlock中的Text就与XML中的curriculum_info的class_name绑定了;

     
  • 相关阅读:
    BZOJ3197:[SDOI2013]刺客信条——题解
    C 程序与 C++ 程序之间的相互调用
    使用Dev C++调试(debug)程序
    ARM 汇编指令 ADR 与 LDR 使用
    华为交换机以 LACP 模式实现链路聚合
    DLCI 简介
    华为路由器帧中继 FR 实验
    GVRP 的工作机制和工作模式
    华为路由器 HDLC 实验
    华为路由器 IPSec 与 GRE 结合实验
  • 原文地址:https://www.cnblogs.com/Elson8080/p/4477632.html
Copyright © 2011-2022 走看看