欢迎光临
我们一直在努力

使用ASP.NET 2.0提供的WebResource管理资源-.NET教程,Asp.Net开发

建站超值云服务器,限时71元/月

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里添加一句:

使用ASP.NET 2.0提供的WebResource管理资源-.NET教程,Asp.Net开发[assembly: webresource(webctrl.cutecat.jpgimage/jpg)]使用ASP.NET 2.0提供的WebResource管理资源-.NET教程,Asp.Net开发

    我们可以看msdn里有webresource的参数说明:第一个是资源的名字,第二个是资源的mime-type名。
    其实这个语句放任何cs文件里,保证放在最高级namespace外就行。

    然后在程序中调用如下:

使用ASP.NET 2.0提供的WebResource管理资源-.NET教程,Asp.Net开发m_image.imageurl = this.page.getwebresourceurl(typeof(webcustom), webctrl.cutecat.jpg);使用ASP.NET 2.0提供的WebResource管理资源-.NET教程,Asp.Net开发

    getwebresourceurl的第一个参数是用户定义的类型(这个是用来确定assembly用的),第二个参数是资源名。

    上面的语句返回给browser的代码是:

使用ASP.NET 2.0提供的WebResource管理资源-.NET教程,Asp.Net开发<img src=”webresource.axd?a=pwebctrl&r=webctrl.cutecat.jpg&t=632390947985312500″ style=”border-width:0px;” />

    其中的src就是getwebesourceurl执行后返回的,它有3个参数(这里的&被解析成了&,不过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>")] 
    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 
赞(0)
版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com 特别注意:本站所有转载文章言论不代表本站观点! 本站所提供的图片等素材,版权归原作者所有,如需使用,请与原作者联系。未经允许不得转载:IDC资讯中心 » 使用ASP.NET 2.0提供的WebResource管理资源-.NET教程,Asp.Net开发
分享到: 更多 (0)