zoukankan      html  css  js  c++  java
  • 组件用户控件引用样式资源(二)---代码引用

    关于样式文件引用方式存在以下弊端(摘自官方)

    When you reference a ResourceDictionary in XAML, a ResourceDictionary object is created each time you reference it.  So if you have 10 custom controls in your library and merge the shared ResourceDictionaries for each control by using XAML, you create 10 identical ResourceDictionary objects.  You can avoid this by creating a static class that returns the ResourceDictionary and merging the resources in code. 

    因此,我们可以通过下面方式规避这个问题

    1. 在基础资源类库中创建资源文件夹Resources,在Resources中创建字典资源样式styles.xaml

        <LinearGradientBrush x:Key="NormalBrush" StartPoint="0,0" EndPoint="0,1">
            <GradientBrush.GradientStops>
                <GradientStopCollection>
                    <GradientStop Color="#Red" Offset="0.0"/>
                    <GradientStop Color="#Blue" Offset="1.0"/>
                </GradientStopCollection>
            </GradientBrush.GradientStops>
        </LinearGradientBrush>

    2. 在Resources中创建类

     public static class SharedDictionaryStyleManager
        {
            static ResourceDictionary _SharedStyleDictionary;
            public static ResourceDictionary SharedStyleDictionary
            {
                get
                {
                    if (_SharedStyleDictionary == null)
                    {
                        System.Uri resourceLocater = new System.Uri("/MyGlobal.Infrustructure;component/Resources/Styles.xaml", System.UriKind.Relative);
                        _SharedStyleDictionary = (ResourceDictionary)Application.LoadComponent(resourceLocater);
                    }
                    return _SharedStyleDictionary;
                }
            }
        }

    3.创建用户控件UPJAppMenuView.xaml,在构造函数前访问加载样式

      public UPJAppMenuView()
            {
                //*************************************引用全局单例样式代码******************************
                this.Resources.MergedDictionaries.Add(SharedDictionaryStyleManager.SharedStyleDictionary);
                InitializeComponent();
            }

    4. 用户控件xaml就可引用了

    <Border Width="auto" Height="auto" BorderBrush="Blue" BorderThickness="10" CornerRadius="10" >
                <Rectangle Stroke="Black" StrokeThickness="2" Fill="{StaticResource NormalBrush}"></Rectangle>       
                
            </Border>

  • 相关阅读:
    免费分享各大快递接口代码
    js 拖动div
    前端开发入门学习笔记(一)
    2017年2月14日
    html表格中的tr td th用法
    转:上传图片并给图片加水印(公共类积累)
    通用防SQL注入代码ASP版
    Firebug 在IE Opera Safari 下这样使用
    [正则表达式]文本框输入内容控制
    图片上传添加水印类
  • 原文地址:https://www.cnblogs.com/jeffry/p/5694565.html
Copyright © 2011-2022 走看看