x:DeferLoadStrategy="Lazy" - 用于指定一个 UIElement 为一个延迟加载元素

  • x:Null - null

示例
1、x:DeferLoadStrategy 通过 FindName 加载
Xaml/DeferLoadStrategy/Demo1.xaml

<Page
x:Class="Windows10.Xaml.DeferLoadStrategy.Demo1"
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
xmlns:local="using:Windows10.Xaml.DeferLoadStrategy"
xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
mc:Ignorable="d"> <Grid Background="Transparent">
<StackPanel Margin="10 0 10 10"> <TextBlock Name="lblMsg" TextWrapping="Wrap" Margin="5" /> <!--
x:DeferLoadStrategy="Lazy" - 其仅作用于 UIElement,可以指定一个 UIElement 为一个延迟加载元素
1、标记为延迟加载的元素必须要指定其 x:Name
2、UIElement 不是在任何情况下都能标记为 x:DeferLoadStrategy="Lazy" 的,不是只有 FindName 才能加载延迟加载元素,具体参见文档:https://msdn.microsoft.com/en-us/windows/uwp/xaml-platform/x-deferloadstrategy-attribute
3、将 UIElement 标记为 x:DeferLoadStrategy="Lazy" 的好处是可以减少页面的启动时间,带来的问题是会增加内存的使用量,每个延迟加载元素大约多耗费 600 字节左右的内存
4、延迟加载元素在加载后,会触发其 Loading 事件
-->
<TextBlock Name="textBlock" Margin="5" x:DeferLoadStrategy="Lazy" /> </StackPanel>
</Grid>
</Page>

Xaml/DeferLoadStrategy/Demo1.xaml.cs

/*
* 演示 x:DeferLoadStrategy 的相关知识点
*
* 本例演示通过“FindName”加载延迟加载元素
*/ using System;
using Windows.UI.Xaml;
using Windows.UI.Xaml.Controls; namespace Windows10.Xaml.DeferLoadStrategy
{
public sealed partial class Demo1 : Page
{
public Demo1()
{
this.InitializeComponent(); this.Loaded += DeferLoadStrategyDemo_Loaded;
} private void DeferLoadStrategyDemo_Loaded(object sender, RoutedEventArgs e)
{
try
{
// 抛出异常
textBlock.Text = "我是 TextBlock";
}
catch (Exception ex)
{
lblMsg.Text += ex.ToString();
lblMsg.Text += Environment.NewLine;
} // 可以通过 FindName() 来加载 x:DeferLoadStrategy="Lazy" 元素
this.FindName(nameof(textBlock)); textBlock.Text = "我是 TextBlock";
}
}
}

2、x:DeferLoadStrategy 通过绑定加载
Xaml/DeferLoadStrategy/Demo2.xaml

<Page
x:Class="Windows10.Xaml.DeferLoadStrategy.Demo2"
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
xmlns:local="using:Windows10.Xaml.DeferLoadStrategy"
xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
mc:Ignorable="d"> <Grid Background="Transparent">
<StackPanel Margin="10 0 10 10"> <TextBox Name="textBox1" Margin="5" /> <!--延迟加载元素-->
<TextBox Name="textBox2" x:DeferLoadStrategy="Lazy" Text="我是 TextBox" Margin="5" /> <!--将 textBox2 与 textBox1 绑定后,textBox2 就会被加载-->
<Button Name="button" Content="将 textBox1 的 Text 绑定到 textBox2 的 Text" Click="button_Click" Margin="5" /> </StackPanel>
</Grid>
</Page>

Xaml/DeferLoadStrategy/Demo2.xaml.cs

/*
* 演示 x:DeferLoadStrategy 的相关知识点
*
* 本例演示通过“绑定”加载延迟加载元素
*/ using Windows.UI.Xaml;
using Windows.UI.Xaml.Controls;
using Windows.UI.Xaml.Data; namespace Windows10.Xaml.DeferLoadStrategy
{
public sealed partial class Demo2 : Page
{
public Demo2()
{
this.InitializeComponent();
} private void button_Click(object sender, RoutedEventArgs e)
{
// 实例化 Binding 对象
Binding binding = new Binding()
{
ElementName = nameof(textBox2), // textBox2 是延迟加载元素,将其与 textBox1 绑定后,textBox2 就会被加载
Path = new PropertyPath(nameof(TextBox.Text)),
Mode = BindingMode.TwoWay,
UpdateSourceTrigger = UpdateSourceTrigger.PropertyChanged
}; // 将目标对象的目标属性与指定的 Binding 对象关联
BindingOperations.SetBinding(textBox1, TextBox.TextProperty, binding);
}
}
}

3、x:DeferLoadStrategy 通过 Storyboard 加载
Xaml/DeferLoadStrategy/Demo3.xaml

<Page
x:Class="Windows10.Xaml.DeferLoadStrategy.Demo3"
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
xmlns:local="using:Windows10.Xaml.DeferLoadStrategy"
xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
mc:Ignorable="d"> <Page.Resources>
<Storyboard x:Name="sb">
<ColorAnimation Storyboard.TargetName="ellipse"
Storyboard.TargetProperty="(Ellipse.Fill).(SolidColorBrush.Color)"
BeginTime="00:00:00"
From="Orange"
To="Blue"
Duration="0:0:3"
AutoReverse="true"
RepeatBehavior="Forever ">
</ColorAnimation>
</Storyboard>
</Page.Resources> <Grid Background="Transparent">
<StackPanel Margin="10 0 10 10"> <!--延迟加载元素-->
<Ellipse x:Name="ellipse" Fill="Orange" Width="200" Height="100" x:DeferLoadStrategy="Lazy" HorizontalAlignment="Left" Margin="5" /> <!--启动一个引用了延迟加载元素的动画后,该延迟加载元素就会被加载-->
<Button Name="button" Content="开始动画" Click="button_Click" Margin="5" /> </StackPanel>
</Grid>
</Page>

Xaml/DeferLoadStrategy/Demo3.xaml.cs

/*
* 演示 x:DeferLoadStrategy 的相关知识点
*
* 本例演示通过“Storyboard”加载延迟加载元素
*/ using Windows.UI.Xaml;
using Windows.UI.Xaml.Controls; namespace Windows10.Xaml.DeferLoadStrategy
{
public sealed partial class Demo3 : Page
{
public Demo3()
{
this.InitializeComponent();
} private void button_Click(object sender, RoutedEventArgs e)
{
// 启动一个引用了延迟加载元素的动画后,该延迟加载元素就会被加载
sb.Begin();
}
}
}

4、x:DeferLoadStrategy 通过 Setter 加载
Xaml/DeferLoadStrategy/Demo4.xaml

<Page
x:Class="Windows10.Xaml.DeferLoadStrategy.Demo4"
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
xmlns:local="using:Windows10.Xaml.DeferLoadStrategy"
xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
mc:Ignorable="d"> <Grid Background="Transparent"> <VisualStateManager.VisualStateGroups>
<VisualStateGroup x:Name="WindowSizeStates">
<VisualState>
<VisualState.StateTriggers>
<AdaptiveTrigger MinWindowWidth="360" />
</VisualState.StateTriggers>
</VisualState>
<VisualState>
<VisualState.StateTriggers>
<AdaptiveTrigger MinWindowWidth="0" />
</VisualState.StateTriggers>
<VisualState.Setters>
<!--窗口宽度小于 360 时调用,此处 setter 引用了延迟加载元素,该延迟加载元素将会被加载-->
<Setter Target="textBox.Foreground" Value="Red" />
</VisualState.Setters>
</VisualState>
</VisualStateGroup> </VisualStateManager.VisualStateGroups> <StackPanel Margin="10 0 10 10"> <!--延迟加载元素-->
<TextBox Name="textBox" Text="我是 TextBox" x:DeferLoadStrategy="Lazy" /> </StackPanel>
</Grid>
</Page>

Xaml/DeferLoadStrategy/Demo4.xaml.cs

/*
* 演示 x:DeferLoadStrategy 的相关知识点
*
* 本例演示通过“Setter”加载延迟加载元素
*/ using Windows.UI.Xaml.Controls; namespace Windows10.Xaml.DeferLoadStrategy
{
public sealed partial class Demo4 : Page
{
public Demo4()
{
this.InitializeComponent();
}
}
}

5、x:DeferLoadStrategy 通过 GetTemplateChild 加载
Xaml/DeferLoadStrategy/Demo5.xaml

<Page
x:Class="Windows10.Xaml.DeferLoadStrategy.Demo5"
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
xmlns:local="using:Windows10.Xaml.DeferLoadStrategy"
xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
mc:Ignorable="d"> <Page.Resources>
<Style TargetType="local:TitledImage">
<Setter Property="HorizontalAlignment" Value="Left" />
<Setter Property="Template">
<Setter.Value>
<ControlTemplate TargetType="local:TitledImage">
<Grid>
<Image Source="{TemplateBinding Source}" Width="200" Height="100" Stretch="Uniform" HorizontalAlignment="Center" VerticalAlignment="Center" />
<!--延迟加载元素,当调用 GetTemplateChild 后,它将被加载-->
<ContentPresenter x:Name="TitlePresenter" x:DeferLoadStrategy="Lazy" Content="{TemplateBinding Title}" HorizontalContentAlignment="Center" VerticalContentAlignment="Center" Foreground="White" />
</Grid>
</ControlTemplate>
</Setter.Value>
</Setter>
</Style>
</Page.Resources> <Grid Background="Transparent">
<StackPanel Margin="10 0 10 10"> <!--对应的 ControlTemplate 中的延迟加载元素 TitlePresenter 不会被加载-->
<local:TitledImage Source="/Assets/SplashScreen.png" /> <!--对应的 ControlTemplate 中的延迟加载元素 TitlePresenter 会被加载(因为调用了 GetTemplateChild)-->
<local:TitledImage Source="/Assets/SplashScreen.png" Title="image title" /> </StackPanel>
</Grid>
</Page>

Xaml/DeferLoadStrategy/Demo5.xaml.cs

/*
* 演示 x:DeferLoadStrategy 的相关知识点
*
* 本例演示通过“GetTemplateChild”加载延迟加载元素
*/ using Windows.UI.Xaml;
using Windows.UI.Xaml.Controls;
using Windows.UI.Xaml.Media;
using Windows.UI.Xaml.Media.Imaging; namespace Windows10.Xaml.DeferLoadStrategy
{
public sealed partial class Demo5 : Page
{
public Demo5()
{
this.InitializeComponent();
}
} // 自定义控件(一个可显示 Title 的 Image)
public class TitledImage : Control
{
// 此自定义控件用于显示 Title 的 ContentPresenter
private ContentPresenter _titlePresenter; public TitledImage()
{
this.DefaultStyleKey = typeof(TitledImage); // 注册一个回调,当 Title 发生变化时触发
this.RegisterPropertyChangedCallback(TitleProperty, TitleChanged);
} // 定义一个依赖属性 Title(用于显示标题)
public static readonly DependencyProperty TitleProperty = DependencyProperty.Register(nameof(Title), typeof(string), typeof(TitledImage), new PropertyMetadata(null));
public string Title
{
get { return (string)GetValue(TitleProperty); }
set { SetValue(TitleProperty, value); }
} // 定义一个依赖属性 Source(用于显示图片)
public static readonly DependencyProperty SourceProperty = DependencyProperty.Register(nameof(Source), typeof(ImageSource), typeof(TitledImage), new PropertyMetadata(null));
public ImageSource Source
{
get { return (BitmapSource)GetValue(SourceProperty); }
set { SetValue(SourceProperty, value); }
} void TitleChanged(DependencyObject sender, DependencyProperty prop)
{
string title = (string)sender.GetValue(prop); if (!string.IsNullOrEmpty(Title) && _titlePresenter == null)
{
// TitlePresenter 是控件模板中的一个延迟加载元素,通过 GetTemplateChild 调用后,它将被加载
_titlePresenter = (ContentPresenter)GetTemplateChild("TitlePresenter");
}
} protected override void OnApplyTemplate()
{
base.OnApplyTemplate(); if (!string.IsNullOrEmpty(Title))
{
// TitlePresenter 是控件模板中的一个延迟加载元素,通过 GetTemplateChild 调用后,它将被加载
_titlePresenter = (ContentPresenter)GetTemplateChild("TitlePresenter");
}
}
}
}

6、x:Null - null
Xaml/NullDemo.xaml

<Page
x:Class="Windows10.Xaml.NullDemo"
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
xmlns:local="using:Windows10.Xaml"
xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
mc:Ignorable="d"> <Grid Background="Transparent">
<StackPanel Margin="10 0 10 10"> <TextBlock Name="lblMsg" TextWrapping="Wrap" Margin="5" /> <!--不指定 Tag 则其默认值为 null-->
<TextBlock Name="textBlock1" Margin="5" /> <!--指定 Tag 的值为 ""-->
<TextBlock Name="textBlock2" Margin="5" Tag="" /> <!--指定 Tag 的值为 null-->
<TextBlock Name="textBlock3" Margin="5" Tag="{x:Null}" /> </StackPanel>
</Grid>
</Page>

Xaml/NullDemo.xaml.cs

/*
* 演示 x:Null 的相关知识点、
*
* 在这里插一句:
* 在 xaml 使用的 {x:Null}, {Binding}, {x:Bind}, {StaticResource} 之类的这种带大括号的语法被称为标记扩展(Markup Extension),在 uwp 中无法开发自定义标记扩展(但是在 wpf 中是可以的)
*/ using System;
using Windows.UI.Xaml;
using Windows.UI.Xaml.Controls; namespace Windows10.Xaml
{
public sealed partial class NullDemo : Page
{
public NullDemo()
{
this.InitializeComponent(); this.Loaded += NullDemo_Loaded;
} private void NullDemo_Loaded(object sender, RoutedEventArgs e)
{
lblMsg.Text = $"textBlock1.Tag: {textBlock1.Tag ?? "null"}"; // null
lblMsg.Text += Environment.NewLine; lblMsg.Text += $"textBlock2.Tag: {textBlock2.Tag ?? "null"}"; // ""
lblMsg.Text += Environment.NewLine; lblMsg.Text += $"textBlock3.Tag: {textBlock3.Tag ?? "null"}"; // null
}
}
}

XAML: x:DeferLoadStrategy, x:Null的更多相关文章

  1. 背水一战 Windows 10 (26) - XAML: x:DeferLoadStrategy, x:Null

    [源码下载] 背水一战 Windows 10 (26) - XAML: x:DeferLoadStrategy, x:Null 作者:webabcd 介绍背水一战 Windows 10 之 XAML ...

  2. XAML

    XAML定义 XAML是一种相对简单.通用的声明式编程语言,它适合于构建和初始化.NET对象. XAML仅仅是一种使用.NET API的方式,把它与HTML.可伸缩向量图形(SVG)或其他特定领域的格 ...

  3. XAML 概述三

    通过对前面2节对XAML的介绍,我们对XAML有了一定的认识.这一节我们来简单了解一下部分XAML命名空间(x:)语言功能. x命名空间映射的是http://schemas.microsoft.com ...

  4. XAML 名称范围 (x:) 语言特性

    本节介绍为 Windows 运行时实现的 XAML 语言特性的参考信息. 本部分内容 主题 描述 x:Class 属性 配置 XAML 编译,在标记和代码隐藏之间连接分部类.代码分部类在一个独立的代码 ...

  5. XAML属性赋值转换之谜(WPF XAML语法解密)

    XAML与XML类似,就是XML延伸过来的.为了更好的表达一些功能,WPF对XML做了扩展,有些功能是WPF在后台悄悄的替你做了.有时候,虽然实现了某个功能,但是对实现原理还是很茫然.今天就讲讲XAM ...

  6. WPF,Silverlight与XAML读书笔记(3) - 标记扩展

    hystar的.Net世界 博客园 首页 新闻 新随笔 联系 管理 订阅 随笔- 103  文章- 0  评论- 107  WPF,Silverlight与XAML读书笔记(3) - 标记扩展   说 ...

  7. 对XAML进行编辑的辅助类(XamlHelper)

    原文:对XAML进行编辑的辅助类(XamlHelper) // XamlHelper.cs// --------------------------------------------// 对XAML ...

  8. 《深入理解JAVA虚拟机》笔记1

    java程序运行时的内存空间,按照虚拟机规范有下面几项: )程序计数器 指示下条命令执行地址.当然是线程私有,不然线程怎么能并行的起来. 不重要,占内存很小,忽略不计. )方法区 这个名字很让我迷惑. ...

  9. 【Win10】UAP/UWP/通用 开发之 x:DeferLoadStrategy

    [Some information relates to pre-released product which may be substantially modified before it's co ...

随机推荐

  1. java 26 - 9 网络编程之 TCP协议多用户上传文件

    TCP实现多用户上传文件: 需要同时给多用户上传文件,这样就得用多线程来实现. 实际上,这样的话,上传的先后顺序和速度就跟客户端的带宽有关:带宽够,就容易抢占到线程的执行权: 首先,创建个线程类:(这 ...

  2. 那些强悍的PHP一句话后门

    强悍的PHP一句话后门这类后门让网站.服务器管理员很是头疼,经常要换着方法进行各种检测,而很多新出现的编写技术,用普通的检测方法是没法发现并处理的.今天我们细数一些有意思的PHP一句话木马.利用404 ...

  3. luogu[1279]字串距离

    题目描述 设有字符串X,我们称在X的头尾及中间插入任意多个空格后构成的新字符串为X的扩展串,如字符串X为”abcbcd”,则字符串“abcb□cd”,“□a□bcbcd□”和“abcb□cd□”都是X ...

  4. luogu2038[NOIP2014 T4]无线网络发射器选址

    题目描述 随着智能手机的日益普及,人们对无线网的需求日益增大.某城市决定对城市内的公共场所覆盖无线网. 假设该城市的布局为由严格平行的129 条东西向街道和129 条南北向街道所形成的网格状,并且相邻 ...

  5. varnish 的一个配置

    backend default { .host = "10.32.26.31"; .port = "; } sub vcl_recv { if (req.url ~ &q ...

  6. Centos 检查磁盘读写性能

    启动Tomcat发现deploy war的速度明显变慢, 怀疑磁盘出问题 测试写入 [tomcat@localhost ~]$ dd if=/dev/zero of=kwxgd bs=64k coun ...

  7. topshelf包装redis为windows服务

    topshelf包装redis为windows服务 Redis服务端目前用的是控制台程序运行,部署的时候能作为windows服务后台运行感觉更好.找到一篇文章Running Redis as a Wi ...

  8. C#一元运算重载的深入理解

    using System; using System.Diagnostics; using System.Text; using System.Collections; using System.Co ...

  9. Hadoop:pig 安装及入门示例

    pig是hadoop的一个子项目,用于简化MapReduce的开发工作,可以用更人性化的脚本方式分析数据. 一.安装 a) 下载 从官网http://pig.apache.org下载最新版本(目前是0 ...

  10. myeclipse中发送邮件出现Exception in thread "main" java.lang.NoClassDefFoundError: com/sun/mail/util/LineInputStream

    出现这个问题的原因是jar包版本不统一,解决方法如下: 我在项目导入了jar包 与myeclipse自带jar冲突了 删除Java EE 5 Libraries/javaee.jar/mail里的包有 ...