顺序中一般会有一些错误代码或标识,为了顺序中轻易这些东西一般不会运用汉字,常常在顺序顶用的是一些FileError或数字。另有就是在编码中常常运用的罗列标识对象的状况。而一般这些信息会直接的或间接的实际给用户,可用户须要到的是轻易明白的汉字形貌。之前要么将这些标识和罗列的转换规则硬编码到顺序中,要么就直接提醒给用户。前者没有很好的扩展性,而后者则让用户一头雾水。现可以用盛行的XML(设置文件)保留提醒信息,然后用一个对象将机械中的内码转换为人们轻易明白的信息。
转换对象以下:
/**//// ///翻译类,将内部码翻译成轻易明白的中文 /// /// ///依据设置文件中的信息,将体系内部码(错误码、胜利码)翻译成中文(或人轻易明白的言语)。 /// publicstaticclassTranslation ...{ privatestaticSystem.IO.FileSystemWatcherwatcher; privatestaticXmlDocumentcontent; privatestaticstringconfigFile; privatestaticobjectlocker=newobject(); /**//// ///加载设置文件 /// /// publicstaticvoidConfigure(stringconfigFile) ...{ LoadFile(configFile); if(watcher!=null) ...{ watcher.Dispose(); } watcher=newFileSystemWatcher(Path.GetDirectoryName(configFile),Path.GetFileName(configFile)); watcher.Changed =newFileSystemEventHandler(watcher_Changed); } /**//// ///加载默许设置文件 /// publicstaticvoidConfigure() ...{ if(System.Web.HttpContext.Current!=null) ...{ Configure(System.Web.HttpContext.Current.Server.MapPath("~/translation.config")); } else ...{ Configure(System.AppDomain.CurrentDomain.SetupInformation.ApplicationBase "\" "translation.config"); } } /**//// ///加载文件内容 /// /// privatestaticvoidLoadFile(stringconfigFile) ...{ lock(locker) ...{ XmlDocumentdoc=newXmlDocument(); doc.Load(configFile); content=doc; Translation.configFile=configFile; } } /**//// ///当文件变动时,重新加载文件 /// /// /// privatestaticvoidwatcher_Changed(objectsender,FileSystemEventArgse) ...{ LoadFile(configFile); } /**//// ///猎取Enum的诠释,假如Enum有Flag标记,则运用逗号分开各个诠释 /// /// /// publicstaticstringGetEnumDescription(EnumenumValue) ...{ returnGetEnumDescription(enumValue,","); } /**//// ///猎取Enum的诠释,假如Enum有Flag标记,则运用sparator分开各个诠释 /// /// /// /// publicstaticstringGetEnumDescription(EnumenumValue,stringsparator) ...{ Typetype=enumValue.GetType(); //搜检范例是不是有Flags特征 object[]attrs=type.GetCustomAttributes(typeof(FlagsAttribute),false); if(attrs.Length>0) ...{ StringBuilderbuilder=newStringBuilder(); Arrayarr=Enum.GetValues(type); foreach(Enumenuinarr)//轮回猎取每个值的诠释 ...{ if((Convert.ToUInt64(enumValue)&Convert.ToUInt64(enu))==Convert.ToUInt64(enu))//推断是不是有这个值 ...{ builder.Append(GetEnumDes(type,enu.ToString())); builder.Append(sparator); } } if(builder.Length!=0)//拿掉末了的分开符 builder.Remove(builder.Length-sparator.Length,sparator.Length); returnbuilder.ToString(); } else ...{ returnGetEnumDes(type,enumValue.ToString()); } } /**//// ///猎取某一Enum范例值的诠释 /// /// /// /// privatestaticstringGetEnumDes(Typetype,stringvalue) ...{ stringxquery="/translation/enum/" type.FullName "/" value; XmlNodenode=content.SelectSingleNode(xquery); if(node!=null) returnnode.InnerText; else returnvalue; } /**//// ///翻译指定值 /// /// /// publicstaticstringGetValueDescription(objectobj) ...{ returnGetValueDescription("default",obj); } /**//// ///在指定组中翻译指定值 /// /// /// /// publicstaticstringGetValueDescription(stringgroup,objectobj) ...{ if(obj==null) return"null"; stringxquery="/translation/description[@group='" group "']/add[@key='" obj.ToString() "']/@value"; XmlNodenode=content.SelectSingleNode(xquery); if(node==null) returnobj.ToString(); else returnnode.Value; } } #p#
在这个对象运用前须要运用Configure要领来加载xml设置文件,默许的设置文件名称为translation.config。转换对象运用单例形式,运用了一个FileSystemWatcher对象来看管XML文件,假如XML有变化,则重新加载。查询XML运用了XPath表达式。
然后即可运用GetEnumDescription和GetValueDescription要领来翻译罗列和标识了。假如没有找到可以翻译的值,则会返回对象的ToString要领的返回值。
示例XML设置:
<?xmlversion="1.0"encoding="utf-8"?> <translation> <enum> <!--此出要用罗列的全名--> <Library.UserType> <Unknow>未知</Unknow> <AfterPayUser>后付费用户</AfterPayUser> <BeforePayUser>预付费用户</BeforePayUser> </Library.UserType> </enum> <descriptiongroup="default"> <addkey="FileErrorl"value="文件已损坏"/> </description> <descriptiongroup="skin"> <addkey="Default"value="默许皮肤"/> </description> <descriptiongroup="topic"> <addkey="space"value="<spanclass='red'>您盈余的空间不足,请您删除部份文件。</span><br/>"/> <addkey="yue"value="<spanclass='red'>您的余额不足,请尽快充值。</span><br/>"/> </description> </translation>
以上就是运用XML将机械内码转换为人们可以明白的信息案例分享的细致内容,更多请关注ki4网别的相干文章!