zoukankan      html  css  js  c++  java
  • 使用ASP.NET 2.0提供的WebResource管理资源(转)

    使用ASP.NET 2.0提供的WebResource管理资源
        ASP.NET(1.0/1.1)给我们提供了一个开发WebControl的编程模型,于是我们摆脱了asp里面的include模式的复用方式。不过1.0/1.1提供的Web控件开发模型对于处理没有image、css等外部资源的组件还算比较得心应手,script虽然很多时候也是外部资源,但在开发控件的时候我们习惯把script使用Page.Register...Script()来嵌入模块,因为紧凑的东西更便于我们复用,用一个dll就可以解决问题又何必要节外生枝呢。

         ASP.NET 2.0提供的Web Resources管理模型,很好的解决了image、css、script等外部资源的管理问题。现在只需要在solution explorer把资源文件的build action属性设为Embedded Resource。然后在assemblyinfo.cs里添加一句:
    [assemblyWebResource("WebCtrl.cutecat.jpg""image/jpg")]
        我们可以看msdn里有WebResource的参数说明:第一个是资源的名字,第二个是资源的mime-type名。
        其实这个语句放任何cs文件里,保证放在最高级namespace外就行。

        然后在程序中调用如下:
    m_Image.ImageUrl = this.Page.GetWebResourceUrl(typeof(WebCustom), "WebCtrl.cutecat.jpg");
        GetWebResourceUrl的第一个参数是用户定义的类型(这个是用来确定assembly用的),第二个参数是资源名。

        上面的语句返回给browser的代码是:
    <img src="WebResource.axd?a=pWebCtrl&amp;r=WebCtrl.cutecat.jpg&amp;t=632390947985312500" style="border-0px;" />
        其中的src就是GetWebesourceUrl执行后返回的,它有3个参数(这里的&被解析成了&amp;,不过IIS也认的),第一个参数a是就是通过typeof(WebCustom)来确定的assembly的名字,第二个参数r很明显就是资源的名字了,第三个参数t是一个a所指的assembly的timestamp。这个t是为了让资源的引用能享用browser缓存的优化,因为IE对相同的url有自己的cache机制。又因为这个r同时又是用户assembly文件的timestamp,如果用户更新了代码,重新编译后t也会变化,这样也就保证了browser能获得最新的资源更新。如果我们能确定嵌入资源是确实不用再更新的,我们可以在typeof()里写一个bcl里的类型,比如typeof(string),那么他将只在freamwork升级后才会变动这个t。

        当然这个WebResource.axd是不存在的,它只是IIS中的一个ISAPI影射。

        使用示例代码如下:
    #region WebResource Demo

    using System;
    using System.Collections.Generic;
    using System.ComponentModel;
    using System.Text;
    using System.Web.UI;
    using System.Web.UI.WebControls;

    [assembly: WebResource(
    "WebCtrl.cutecat.jpg""image/jpg")]

    namespace WebCtrl
    {
        [DefaultProperty(
    "Text")]
        [ToolboxData(
    "<{0}:WebCustom runat=server></{0}:WebCustom>")]
        
    public class WebCustom : WebControl
        
    {
            
    private string text;
            
    private Image m_Image;

            [Bindable(
    true)]
            [Category(
    "Appearance")]
            [DefaultValue(
    "")]
            
    public string Text
            
    {
                
    get return text; }
                
    set { text = value; }
            }


            
    protected override void CreateChildControls()
            
    {
                m_Image 
    = new Image();
                
    this.Controls.Add(m_Image);
            }


            
    protected override void Render(HtmlTextWriter output)
            
    {
                m_Image.ImageUrl 
    = this.Page.GetWebResourceUrl(typeof(WebCustom), "WebCtrl.cutecat.jpg");
                
    this.RenderChildren(output);
            }

        }

    }

    #endregion
    签名内容 FuckMe 123123123!
  • 相关阅读:
    关于 转换图片url为base64格式以及base64格式图片地址转为图片文件
    rem布局在Androidwebview中页面错乱
    vue中 $event 的用法--获取当前父元素,子元素,兄弟元素
    vue实现动态改变title
    vue页面跳转-携带参数
    vue项目打包部署生产环境
    Mark区
    kma 2019CSP前刷题记录
    机房的沙茶日常
    2019NOIP算法复健+学习
  • 原文地址:https://www.cnblogs.com/imcooler/p/1487114.html
Copyright © 2011-2022 走看看