在项目中经常需要实现多语言其中包括webpart的属性也需要。那么如何实现呢?

首先需要资源文件,利用资源文件实现语言的翻译,如下图:

创建好资源后,下面我们来实现webpart属性的多语言。方法代码如下:

   1: using System;

   2: using System.Collections.Generic;

   3: using System.Text;

   4: using System.Globalization;

   5: using System.Web;

   6: using System.Web.UI.WebControls.WebParts;

   7: using System.ComponentModel;

   8: //****************************************************************

   9: //编制人:XX

  10: //编制作用:本地化WebPart的Category、WebDisplayName 和 WebDescription 属性

  11: //编制时间:2013-05-07

  12: //编制单位:XX

  13: //****************************************************************

  14: namespace TCL.EP.SPCommon

  15: {

  16:     #region//WebPart类别本地化

  17:     public sealed class LocalizedCategoryAttribute : CategoryAttribute

  18:     {

  19:         public LocalizedCategoryAttribute(string category)

  20:             : base(category)

  21:         { }

  22:  

  23:         // Override this method to return values from the webpart's resource file.

  24:         protected override string GetLocalizedString(string value)

  25:         {

  26:             return LocalizedUtility.GetLocalizedString(value, CultureInfo.CurrentUICulture.LCID);

  27:         }

  28:     }

  29:     #endregion

  30:  

  31:     #region//WebPart显示名称本地化

  32:     public sealed class LocalizedWebDisplayNameAttribute : WebDisplayNameAttribute

  33:     {

  34:         bool m_isLocalized;

  35:  

  36:         public LocalizedWebDisplayNameAttribute(string displayName)

  37:             : base(displayName)

  38:         { }

  39:  

  40:         // Override this property to return values from the webpart's resource file.

  41:         public override string DisplayName

  42:         {

  43:             get

  44:             {

  45:                 if (!m_isLocalized)

  46:                 {

  47:                     this.DisplayNameValue = LocalizedUtility.GetLocalizedString(base.DisplayName, CultureInfo.CurrentUICulture.LCID);

  48:                     m_isLocalized = true;

  49:                 }

  50:                 return base.DisplayName;

  51:             }

  52:         }

  53:     }

  54:     #endregion

  55:  

  56:     #region//WebPart描述本地化

  57:     public sealed class LocalizedWebDescriptionAttribute : WebDescriptionAttribute

  58:     {

  59:         bool m_isLocalized;

  60:  

  61:         public LocalizedWebDescriptionAttribute(string description)

  62:             : base(description)

  63:         { }

  64:  

  65:         // Override this property to return values from the webpart's resource file.

  66:         public override string Description

  67:         {

  68:             get

  69:             {

  70:                 if (!m_isLocalized)

  71:                 {

  72:                     this.DescriptionValue = LocalizedUtility.GetLocalizedString(base.Description, CultureInfo.CurrentUICulture.LCID);

  73:                     m_isLocalized = true;

  74:                 }

  75:                 return base.Description;

  76:             }

  77:         }

  78:     }

  79:     #endregion

  80: }

调用例子如下:

 

   1: /// <summary>

   2:       /// 图片打开的URL

   3:       /// </summary>

   4:       [WebBrowsable(true)]

   5:       [LocalizedWebDisplayName("TCL.WebPartAttribute.PhotoImageUrl")]

   6:       [LocalizedWebDescription("TCL.WebPartAttribute.PhotoImageUrl")]

   7:       [Personalizable(PersonalizationScope.Shared)]

   8:       [LocalizedCategory("TCL.WebPartAttribute.SelfName")]

   9:       public string PhotoImageUrl { get; set; }

sharepoint2010如何本地化WebPart的Category、WebDisplayName 和 WebDescription 属性的更多相关文章

  1. 给category添加基本数据类型属性

    给category添加基本数据类型属性 说明 通常,我们添加属性都是通过对象扩展来实现的,其实,我们也可以用runtime来添加基本数据类型的属性 源码 // // UIView+AnimationP ...

  2. iOS category中的所谓属性 和 从xib初始化对象的方法 以及类扩展

    今天在编码时遇到以下代码 @interface UITextField (TCCustomFont) @property (nonatomic, copy) NSString* fontName; @ ...

  3. category类别中添加属性

    p.p1 { margin: 0.0px 0.0px 0.0px 0.0px; font: 18.0px Menlo; color: #c91b13 } p.p2 { margin: 0.0px 0. ...

  4. SharePoint 2013 图文开发系列之WebPart

    这是我们介绍SharePoint开发入门的第一篇,在这一篇里,我们会介绍SharePoint开发的几个关键物理路径,一些开发技巧和最基础的WebPart开发. 开发工具 在SharePoint 201 ...

  5. Sharepoint 2010 之 WebPart

    转:http://blog.csdn.net/bestbadgod/article/details/6895542 Sharepoint系列的博客,都是我个人自学过程中的点滴的积累,毕竟没做过C#及A ...

  6. SharePoint 2013 图文开发系列之可视化WebPart

    有了WebPart开发的基础,再进行可视化WebPart开发,就容易多了.创建和开发过程,两者非常相似,下面,我们简单介绍下可视化WebPart的开发. 1.添加新项目,选择SharePoint 20 ...

  7. 【原】iOS动态性(一):动态添加属性的方法——关联(e.g. 向Category添加属性)

    想到要如何为所有的对象增加实例变量吗?我们知道,使用Category可以很方便地为现有的类增加方法,但却无法直接增加实例变量.不过从Mac OS X v10.6开始,系统提供了Associative ...

  8. Objective-C :Category

    Category 引入 在日常的开发中,可能会碰到这样的需求:给某个类增加方法.比如说,需要给NSString类增加一个打印的方法.当然,我们可以新建一个类比如TestString,并继承NSStri ...

  9. iOS动态性:动态添加属性的方法——关联(e.g. 向Category添加属性)

    想到要如何为所有的对象增加实例变量吗?我们知道,使用Category可以很方便地为现有的类增加方法,但却无法直接增加实例变量.不过从Mac OS X v10.6开始,系统提供了Associative ...

随机推荐

  1. Hard Drive Inspector Pro 4.26.208(硬盘检测工具)简体中文特别版

    Hard Drive Inspector监视硬盘错误并且接收警报,检查变化并实施诊断.例如:驱动器旋转时间增加以及数次重试才能运转驱动器通常意味着发动机和/或者轴存在可以导致数据丢失的错误.HardD ...

  2. Linux菜鸟级重点

    这是本人自学Linux所做的笔记,以及实现一些功能作的总结.乐意与各位喜欢linux的朋友交流学习,共同进步.这篇文章只是简单介绍一些linux比较常用的或者说是最基础的也是最重要的知识,有些在模块后 ...

  3. 如何用Ajax加载服务器的图片

    用Ajax请求服务器的图片,并显示在浏览器中 前言 一直在数据库里面存的都是图片在服务器的地址,然后再到浏览器中显示,但是发现两个问题 第一:为了安全起见,js是无法读取本地的图片的,不然你写一个js ...

  4. Elasticsearch聚合初探——metric篇

    Elasticsearch是一款提供检索以及相关度排序的开源框架,同时,也支持对存储的文档进行复杂的统计--聚合. 前言 ES中的聚合被分为两大类:Metric度量和bucket桶(原谅我英语差,找不 ...

  5. 未能加载文件或程序集“System.Web.Http.WebHost, Version=4.0.0.0, ”或它的某一个依赖项。系统找不到指定的文件。

    一:错误提示 "未能加载文件或程序集"System.Web.Http.WebHost, Version=4.0.0.0, Culture=neutral, PublicKeyTok ...

  6. canvas导出图片方法总结

    html代码 <canvas id="canvas" width="100" height="100" ></canvas ...

  7. Stream Player control

    In this article you will find an implementation of a stream player control. Download WPF demo - 11 M ...

  8. 使用NVelocity生成内容的几种方式

    使用NVelocity也有几个年头了,主要是在我的代码生成工具Database2Sharp上使用来生成相关代码的,不过NVelocity是一个非常不错的模板引擎,可以用来生成文件.页面等相关处理,非常 ...

  9. 基于MVC4+EasyUI的Web开发框架经验总结(1)-利用jQuery Tags Input 插件显示选择记录

    最近花了不少时间在重构和进一步提炼我的Web开发框架上,力求在用户体验和界面设计方面,和Winform开发框架保持一致,而在Web上,我主要采用EasyUI的前端界面处理技术,走MVC的技术路线,在重 ...

  10. webstorage[html5的本地数据处理]

    1.webStorage是什么? webStorage是html5中用于本地化存储的一种方式,而在之前呢我们是用cookie的存储方式处理; 2.那它们之间的区别是什么? Ⅰ.cookie存在的问题: ...