WPF 基础 - x 名称空间详解
| 名称 | 种类(默认Attribute) | 备注 |
|---|---|---|
| x:Array | 标记拓展 | 可作为 ListBox.ItemsSource 的值 |
| x:Class | 指定与 .cs 中哪个类合并,所指示的类型在声明时使用 partial 关键字 | |
| x:ClassModifier | 指定标签编译生成的类具有怎样的访问控制级别,跟类型的访问级别要一致 public、internal | |
| x:Code | XAML 指令元素 | 把代码后置的 C# 代码写到 xaml 中 |
| x:FieldModifier | 当从一个程序集访问另一个程序集的窗体的元素时,就需要把被访问控件的引用变量改为 public 级别 | |
| x:Key | 标注资源,其他地方可以通过 key 值找到这个资源 | |
| x:Name | 标注标签,其他标签或后置代码可以通过 Name 值找到这个资源 | |
| x:Null | 标记拓展 | 表示空值,一般用于有默认值但是又不需要这个默认值时。如:Sytle="{x:Null}" |
| x:Shared | 默认为 true,与 x:key 一起配合使用,表示调用资源时是否每次得到的都是同一个对象。 | |
| x:Static | 标记拓展 | 调用某个类的静态属性 |
| x:Subclass | ||
| x:Type | 标记拓展 | 1)编程层面:数据类型,创建对象时开辟相应大小的内存;2)逻辑层面:抽象和封装的结果 |
| x:TypeArguments | ||
| x:Uid | 元素的唯一标识符 | |
| x:XData | XAML 指令元素 | 用于资源中的 XmlDataProvider 标签 |
1. x:type 示例
public class MyButton : Button
{
public Type UserWindowType { get; set; }
protected override void OnClick()
{
base.OnClick();
Window win = Activator.CreateInstance(this.UserWindowType) as Window;
if (win != null)
{
win.ShowDialog();
}
}
}
<Window x:Class="WpfApp1.CommandMode.MyWindow"
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
xmlns:local="clr-namespace:WpfApp1.CommandMode"
mc:Ignorable="d"
Title="MyWindow" Height="450" Width="800">
<Grid Background="Yellow">
</Grid>
</Window>
<!--把 MyWindow 作为一种数据类型赋值给 MyButton.UserWindowType-->
<local:MyButton UserWindowType="{x:Type local:MyWindow}" Content="OpenMyWindow"/>
<Style TargetType="TextBox" BasedOn="{StaticResource {x:Type TextBox}}">
</Style>
2. x:Array 示例
x:Null、x:Type 两个标记拓展一般用更简洁的方式即用花括号括起来的字符串作为值赋给标签 Attribute 的形式。但 x:Array 必须用标记拓展的方式。
<Window ...
xmlns:sys="clr-namespace:System;assembly=mscorlib">
</Window>
<!--如果是简洁写法:并不能给 ArrayExtension 的 只读属性 Items 赋值-->
<ListBox ItemsSource="{x:Array Type=sys:String}"/>
<!--正确写法-->
<ListBox>
<ListBox.ItemsSource>
<x:Array Type="{x:Type sys:String}">
<sys:String>hallo1</sys:String>
<sys:String>hallo2</sys:String>
<sys:String>hallo3</sys:String>
</x:Array>
</ListBox.ItemsSource>
</ListBox>
<!--等同于-->
<ListBox>
<ListBox.Items>
<sys:String>hallo1</sys:String>
<sys:String>hallo2</sys:String>
<sys:String>hallo3</sys:String>
</ListBox.Items>
</ListBox>
3. x:XData 示例
<Window.Resources>
<XmlDataProvider x:Key="XMlData">
<x:XData>
<Super xmlns="">
<Colors>
<Color>红</Color>
<Color>绿</Color>
<Color>黄</Color>
</Colors>
<Sexs>
<Sex>男</Sex>
<Sex>女</Sex>
</Sexs>
</Super>
</x:XData>
</XmlDataProvider>
</Window.Resources>
<StackPanel>
<!--红绿黄各一行-->
<ListBox ItemsSource="{Binding Source={StaticResource XMlData}, XPath=/Super/Colors/Color}">
<!--男女各一行-->
<ListBox ItemsSource="{Binding Source={StaticResource XMlData}, XPath=/Super/Sexs/Sex}">
<!--红绿黄男女总共一行-->
<ListBox ItemsSource="{Binding Source={StaticResource XMlData}, XPath=/Super}">
</StackPanel>
WPF 基础 - x 名称空间详解的更多相关文章
- 深入浅出WPF-04.x名称空间详解
x名称空间详解 几个需要特别说明的名称空间: x:Class 用来标记XAML和后台代码之间的合并关系.x:Class根节点的类型必须和x:Class值指向的类型保持一致.x:Class的值指向的类型 ...
- WPF读书笔记 x名称空间详解(第二天)
每天看一点,每天进步一点. x名称空间映射的是http://schemas.microsoft.com/winfx/2006/xaml,它包含的类均与解析XAML语言关,亦可称为"XAML名 ...
- [No000013F]WPF学习之X名称空间详解
X名称空间里面的成员(如X:Name,X:Class)都是写给XAML编译器看的.用来引导XAML代码将XAML代码编译为CLR代码. 4.1X名称空间里面到底都有些什么? x名称空间映射的是:htt ...
- WPF学习之X名称空间详解
X名称空间里面的成员(如X:Name,X:Class)都是写给XAML编译器看的.用来引导XAML代码将XAML代码编译为CLR代码. 4.1X名称空间里面到底都有些什么? x名称空间映射的是:htt ...
- 9、XAML名称空间详解
XAML命名空间 <Window xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation" ...
- WPF之X名称空间学习
WPF的X名称空间都有什么呢?首先,盗用张图来说明: 我将就图表中的内容进行总结: 1.x:Array具有一个Iteams属性,它能暴漏一个ArratList实例,ArratList实例的内部成员类型 ...
- ELK&ElasticSearch5.1基础概念及配置文件详解【转】
1. 配置文件 elasticsearch/elasticsearch.yml 主配置文件 elasticsearch/jvm.options jvm参数配置文件 elasticsearch/log4 ...
- Linux基础知识之挂载详解(mount,umount及开机自动挂载)
Linux基础知识之挂载详解(mount,umount及开机自动挂载) 转载自:http://www.linuxidc.com/Linux/2016-08/134666.htm 挂载概念简述: 根文件 ...
- Qt零基础教程(四) QWidget详解篇
在博客园里面转载我自己写的关于Qt的基础教程,没次写一篇我会在这里更新一下目录: Qt零基础教程(四) QWidget详解(1):创建一个窗口 Qt零基础教程(四) QWidget详解(2):QWid ...
随机推荐
- Node.js require 模块加载原理 All In One
Node.js require 模块加载原理 All In One require 加载模块,搜索路径 "use strict"; /** * * @author xgqfrms ...
- post upload file & application/x-www-form-urlencoded & multipart/form-data
post upload file application/x-www-form-urlencoded & multipart/form-data https://stackoverflow.c ...
- Swift 5.1
Swift 5.1 WebView & WKWebView https://developer.apple.com/swift-playgrounds/ https://developer.a ...
- element-ui的树型结构图,带有复选框的,没有子项的,横排展示
// 修改树形图样式,如果不含有下箭头的块,要变成行内样式 treeChildInline(){ let hasCaretRight = $("#permission_panel" ...
- jquery.query.js
帮助文档 var url = location.search; > "?action=view§ion=info&id=123&debug&te ...
- Renice INC:不同颜色的酒帽所代表的意义
酒帽就是酒瓶上方的热缩胶帽/锡帽/蜡封,也就是开瓶前要割掉的那一层保护物,所有的法国酒在酒帽上,都会有一个圆形贴纸,除了有不同颜色外,上面还有一串号码,有可能很多人在喝酒时都不会对这个酒帽有更多的在意 ...
- MySQL学习04(DQL查询)
DQL查询 DQL语言 DQL( Data Query Language 数据查询语言 ) 查询数据库数据 , 如SELECT语句 简单的单表查询或多表的复杂查询和嵌套查询 是数据库语言中最核心,最重 ...
- Markdown简单语法的使用
Markdown简单语法的使用 目录 Markdown简单语法的使用 前言 标题的设置 字体的设置 1.字体加粗 2.斜体 3.字体加粗斜体 3.删除线 引用 列表的使用 插入图片 分割线 代码的书写 ...
- 基于nginx实现上游服务器动态自动上下线——不需reload
网上关于nginx的介绍有很多,这里讲述的是上游服务(如下图的Java1服务)在没有"网关"的情况下,如何通过nginx做到动态上下线. 传统的做法是,手动修改nginx的upst ...
- Excel和CSV格式文件的不同之处
来源:https://blog.csdn.net/weixin_39198406/article/details/78705016 1.个人理解:为何选择使用csv来存储接口测试用例相关字段数据,而不 ...