ResourceManager

            ResourceManager aa = new ResourceManager("ConsoleApplication1.Resource1", Assembly.GetExecutingAssembly());
            //CultureInfo ci = Thread.CurrentThread.CurrentCulture;

            Console.WriteLine(aa.GetString("String1", System.Globalization.CultureInfo.CurrentCulture));

 

 

vs2003中的使用

 

vs2005中的使用

 

Resources.SceneErrorCode.err302

 

 

asp.net中的使用

        Response.Write(Resources.Resource.ResourceManager.GetString("ads"));
        Response.Write(Resources.Resource.String1);


         //System.Resources.ResourceManager rm = new System.Resources.ResourceManager("Resources.Resource", System.Reflection.Assembly.GetExecutingAssembly());
         //Response.Write(rm.GetString("ads"));

       
         this.GetGlobalResourceObject(className, key);//App_GlobalResources怎么用,还不知道
         HttpContext.GetLocalResourceObject(virturalPath, resourceKey);//App_LocalResources,怎么用,还不知道

 

=================================

用户控件中

[assembly: WebResource("Cnto.WebControls.UploadPic.x.gif", "image/gif")]

[assembly: WebResource("Cnto.WebControls.CalenderBox.ScsComboBoxUtil.js", "text/javascript", PerformSubstitution = true)]

 

调用时

            Page.ClientScript.RegisterClientScriptResource(this.GetType(), "Cnto.WebControls.CalenderBox.ScsComboBoxUtil.js");
            if (String.IsNullOrEmpty(this.ImageUrl))
            {
                this.ImageUrl = Page.ClientScript.GetWebResourceUrl(this.GetType(), "Cnto.WebControls.CalenderBox.DropArrow.gif");

这个是不是资源文件,编译时指定.,资源文件都是使用ResXFileCodeGenerator工具,而这个没有使用,还是自动产生一个rsx文件,再引用该文件,然后输出流时,指定格式.

 

        internal static System.Drawing.Bitmap Image1 {
            get {
                object obj = ResourceManager.GetObject("Image1", resourceCulture);
                return ((System.Drawing.Bitmap)(obj));
            }
        }

图片这样引用

 

 

也可以在AssemblyInfo.cs中指定Resouces文件,然后再用一定的方式使用...

 

不管哪种,应该本质是都是使用ResourceManager 相关的类,来获取相关数据.

 

而webResouce,是对ResourceManager 的再包装,在输出时,以http流的方式输出

 

==============================

注:本文基于.NET 2.0 和 VS2005

我们在编写 Server Control 的时候难免要用到一些客户端脚本(javascript),如何把脚本和编译好的dll一起发布就成了一个问题。把一段一段的javascript block写在cs文件里是一件很“丑陋”的事情,javascript就应呆在*.js文件里。js文件怎样才能“打包”到dll里呢?查了很多文档,最后实践下来发现有很多细节是需要注意的。整理出来,免得大家走弯路。废话无多,让我们开始。

Step 0: 我们已有的
1. 网站项目:Website1 ,其中:  
        Default.aspx (空页面)
2. WebControl库项目:WebControlLibrary1 ,其中: 
        ClientScriptResourceLabel.cs

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

namespace  WebControlLibrary1
{
    
public   class  ClientScriptResourceLabel : WebControl
    {

    }
}

        script_include.js

function  DoClick() {Form1.Message.value = 'Text from resource script.'}

 


Step 1:
在script_include.js文件的属性窗口里,把Build Action改为:Embedded Resource
 


Step 2:

ClientScriptResourceLabel.cs 中加入

[assembly: WebResource("script_include.js""application/x-javascript")]
namespace WebControlLibrary1
{
....

注意这句是在namespace之外。你也可以把这句加在AssemblyInfo.cs文件里,.NET的类库就是统一加在AssemblyInfo.cs文件里的。


很多文档(包括MSDN)里都说通过以上两步就可以把js文件作为资源,捆绑到dll中了。但实际上更本就不能用。我们用Reflector来看看编译出来的到底是什么东东。

怎么变成 WebControlLibrary1.script_include.js 了?!问题是出在“默认名称空间”。VS会自动把default namespace加到资源文件前面。其实只要把默认名称空间改为空就可以了。令人郁闷的是VS2005正式版不允许把default namespace改为空(beta2是允许的)。怎么办呢?难道要用麻烦的命令行来编译吗?还有一个办法就是手工修改项目文件。

Step 3:
用写字板打开WebControlLibrary1.csproj文件,把其中的RootNamespace 改为空

   < PropertyGroup >
    
< Configuration  Condition =" '$(Configuration)' == '' " > Debug </ Configuration >
    
< Platform  Condition =" '$(Platform)' == '' " > AnyCPU </ Platform >
    
< ProductVersion > 8.0.50727 </ ProductVersion >
    
< SchemaVersion > 2.0 </ SchemaVersion >
    
< ProjectGuid > {65431F13-ABAE-4281-A860-90FEC739AFED} </ ProjectGuid >
    
< OutputType > Library </ OutputType >
    
< AppDesignerFolder > Properties </ AppDesignerFolder >  
    <RootNamespace></RootNamespace>
 
    
< AssemblyName > WebControlLibrary1.web </ AssemblyName >
  
</ PropertyGroup >


这样一来“默认名称空间”就没有了:



Step 4:
编译WebControlLibrary1,这下得到的是我们想要的了:


Step 5
: 
调用脚本资源(ClientScriptResourceLable.cs)

     public   class  ClientScriptResourceLabel : WebControl
    {
        
protected   override   void  OnPreRender(EventArgs e)
        {
            
if  ( this .Page  !=   null )
            {
                ClientScriptManager manager1 
=   this .Page.ClientScript;
                manager1.RegisterClientScriptResource(
typeof (ClientScriptResourceLabel),  " script_include.js " );
            }
            
base .OnPreRender(e);
        }
    }


 

Step 6
终于可以在页面里使用包装好的控件了(Default.aspx):

<% @ Page Language = " C# "   %>

<% @ Register Assembly = " WebControlLibrary1 "  Namespace = " WebControlLibrary1 "  TagPrefix = " cc1 "   %>
< html >
< head  runat ="server" >
    
< title > Script Resource </ title >
</ head >
< body >
    
< form  id ="Form1"  runat ="server" >
        
< div >
            
< input  type ="text"  id ="Message" >
            
< input  type ="button"  onclick ="DoClick()"  value ="ClientClick" >
            
< cc1:ClientScriptResourceLabel  ID ="ClientScriptResourceLabel1"  runat ="server"   />
        
</ div >
    
</ form >
</ body >
</ html >

生成的页面是这样的:

< html >
< head >< title >
    Script Resource
</ title ></ head >
< body >
    
< form  name ="Form1"  method ="post"  action ="Default.aspx"  id ="Form1" >
< div >
< input  type ="hidden"  name ="__VIEWSTATE"  id ="__VIEWSTATE"  value ="/wEPDwUKLTkwOTU4NDc0OGRkO0UjKICXV1XisDv/KKM/wA+05FQ="   />
</ div >

<script src="/WebSite1/WebResource.axd?d=E2u_4K_tSvgEe7jglgaDJYjGQkJj2ZwZEqAWVi3afWYe4CI30IeNjer7_ojoLKjr0&amp;t=632688246616562500" type="text/javascript"></script>
        
< div >
            
< input  type ="text"  id ="Message" >
            
< input  type ="button"  onclick ="DoClick()"  value ="ClientClick" >
            
< span  id ="ClientScriptResourceLabel1" ></ span >
        
</ div >
    
</ form >
</ body >
</ html >

其中的<script src="/WebSite1/WebResource.axd?d=...... 就是对脚本资源的调用。


注意:除了default namespace会影响编译出来的脚本资源文件名外,文件所在的位置也会作为前缀加到文件名上。例如你把script_include.js放到 JS 目录下,编译出来就会变成 JS.scritp_include.js

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值