博客
关于我
Silverlight学习笔记:资源的位置
阅读量:428 次
发布时间:2019-03-06

本文共 1267 字,大约阅读时间需要 4 分钟。

在Web项目中,我们不可避免地需要使用图片、音频、视频、字体等非可执行的数据文件,这些通常被称为资源文件。在Silverlight中,资源文件的引用方法有多种,下面将从实际操作角度对其进行详细介绍。

一、资源文件的引用方法

Silverlight应用程序的资源文件可以通过以下几种方式引用:

  • 嵌入应用程序包

    这是最常见的引用方式。资源文件会被嵌入到生成的XAP文件中。这种方式的缺点是增加了XAP文件的大小,但它的简单性和普遍性使其成为开发者常用的选择。

  • 按需检索

    如果资源文件不需要立即加载,可以通过从外部地址(如网站的ClientBin目录)动态加载的方式实现。这种方式适合资源文件较大或加载频率较低的情况。

  • 嵌入程序集

    如果需要将资源文件作为程序集的一部分嵌入,可以通过将资源文件添加到项目中,并设置其Build Action为"Resource"。这种方式与嵌入应用程序包的效果类似,但在某些场景下可能更灵活。

  • 按需检索的程序集嵌入

    这种方式结合了嵌入程序集和按需加载的优点。资源文件会被嵌入到程序集中,但在需要时会动态加载,这样既减小了XAP文件的大小,又提高了加载效率。

  • 二、Build Action的配置

    在Silverlight项目中,资源文件的引用还与其Build Action的设置密切相关。Build Action有三种常见设置:

  • Resource(默认设置)

    选择这个选项会将资源文件嵌入到生成的XAP文件中。这种方法适用于需要将资源文件直接嵌入到应用程序中的场景。

  • Content

    选择这个选项会将资源文件作为内容文件处理。这种方式通常用于需要在XAML中引用静态资源(如字体文件)的情况,资源文件不会被嵌入到XAP文件中,而是保留在项目目录中。

  • None

    选择这个选项表示资源文件不会被嵌入到XAP文件中,而是作为外部文件加载。这种方式适用于需要从特定路径或服务器动态加载资源文件的情况。

  • 三、资源文件的引用最佳实践

  • 资源文件的存储位置

    • 如果选择"Resource"或"None",则资源文件应放置在与Silverlight应用程序同一目录中的ClientBin子目录中。
    • 如果选择"Content",则资源文件应放置在项目目录中。
  • 相对路径与绝对路径

    • 如果使用相对路径(如"./blend.jpg"),则Silverlight会从XAP文件的根目录开始搜索资源文件。
    • 如果使用绝对路径(如"http://localhost:7323/009_uri.Web/ClientBin/blend.jpg"),则需要确保服务器上有相应的配置。
  • 动态加载优化

    • 对于大型资源文件或频繁加载的资源,可以使用Silverlight的BackgroundLoader来优化加载性能。
  • 四、总结

    通过合理配置Build Action和资源文件的引用方式,可以在Silverlight项目中实现资源文件的高效管理和灵活使用。无论是嵌入到XAP文件中,还是通过动态加载,开发者都可以根据具体需求选择最优方案。

    转载地址:http://anrkz.baihongyu.com/

    你可能感兴趣的文章
    Nginx配置——不记录指定文件类型日志
    查看>>
    Nginx配置代理解决本地html进行ajax请求接口跨域问题
    查看>>
    Nginx配置参数中文说明
    查看>>
    Nginx配置好ssl,但$_SERVER[‘HTTPS‘]取不到值
    查看>>
    Nginx配置如何一键生成
    查看>>
    Nginx配置实例-负载均衡实例:平均访问多台服务器
    查看>>
    NHibernate学习[1]
    查看>>
    NIFI1.21.0_Mysql到Mysql增量CDC同步中_日期类型_以及null数据同步处理补充---大数据之Nifi工作笔记0057
    查看>>
    NIFI1.21.0_NIFI和hadoop蹦了_200G集群磁盘又满了_Jps看不到进程了_Unable to write in /tmp. Aborting----大数据之Nifi工作笔记0052
    查看>>
    NIFI1.21.0通过Postgresql11的CDC逻辑复制槽实现_指定表多表增量同步_增删改数据分发及删除数据实时同步_通过分页解决变更记录过大问题_02----大数据之Nifi工作笔记0054
    查看>>
    NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_配置binlog_使用处理器抓取binlog数据_实际操作01---大数据之Nifi工作笔记0040
    查看>>
    NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_配置数据路由_实现数据插入数据到目标数据库_实际操作03---大数据之Nifi工作笔记0042
    查看>>
    NIFI同步MySql数据_到SqlServer_错误_驱动程序无法通过使用安全套接字层(SSL)加密与SQL Server_Navicat连接SqlServer---大数据之Nifi工作笔记0047
    查看>>
    Nifi同步过程中报错create_time字段找不到_实际目标表和源表中没有这个字段---大数据之Nifi工作笔记0066
    查看>>
    NIFI大数据进阶_离线同步MySql数据到HDFS_02_实际操作_splitjson处理器_puthdfs处理器_querydatabasetable处理器---大数据之Nifi工作笔记0030
    查看>>
    NIFI大数据进阶_连接与关系_设置数据流负载均衡_设置背压_设置展现弯曲_介绍以及实际操作---大数据之Nifi工作笔记0027
    查看>>
    NIFI数据库同步_多表_特定表同时同步_实际操作_MySqlToMysql_可推广到其他数据库_Postgresql_Hbase_SqlServer等----大数据之Nifi工作笔记0053
    查看>>
    NIFI汉化_替换logo_二次开发_Idea编译NIFI最新源码_详细过程记录_全解析_Maven编译NIFI避坑指南001---大数据之Nifi工作笔记0068
    查看>>
    NIFI集群_内存溢出_CPU占用100%修复_GC overhead limit exceeded_NIFI: out of memory error ---大数据之Nifi工作笔记0017
    查看>>
    NIFI集群_队列Queue中数据无法清空_清除队列数据报错_无法删除queue_解决_集群中机器交替重启删除---大数据之Nifi工作笔记0061
    查看>>