创建自定义的Visual Studio项模板

原创 2007年10月09日 14:16:00
关键词: VisualStudio 模板 VSDIR    VIZ
目的:     创建自己的Visual Studio类模板,以创建实现单例模式(Singleton)的类为例。

1、何为模板?
    可以通过两个例子来简单说明一下。
    当我们在Visual Studio.Net中选择新建项目时,向导通常会提供一些预定义类型的项目供选择,比如“Window应用程序”、“ASP.NET Web应用程序”等。只要你选定其中一个并确定,VS会自动相应的项目结构和部分它认为有用的代码。这些供选择的东东就是模板的一种,叫项目模板(Project Template)
    当我们要在项目中增加某种文件,通常可以使用“添加新项”来实现。例如增加一个新的类或是XML文件等等。此时我们所选择选择的类型也是VS预定义的模板的一种,叫项模板(Item Template)。

2、为什么要使用模板? 
    模板的着眼点是开发效率上,也就是说通过这些模板我们可以让VS自动生成一些常用的文件,并初始化结构和代码以加快开发速度。
     典型的就是VS中“添加新项”时可供选择的那些模板(如组件类、用户控件等等)。

    这篇Post主要关注的是项模板的创建及应用。创建项目模板的方式与此类似可以参考:http://www.carlosag.net/Articles/createVSTemplate.aspx

3、用项模板来做什么?
    既然要创建自己的项模板,那么就要明确打算让这个模板来做什么。既然前面提到了模式,那创建一个能够自动实现单例模式(Singleton)的类的项模板。(BTW:关于Singleton模式本身可以参见:http://www.yoda.arachsys.com/csharp/singleton.html。关于它讨论,这里有一篇http://www.jdon.com/jive/article.jsp?forum=91&thread=17578。)
    这里先给出一种最简单的实现Singleton模式的示例:
    
public sealed class Singleton
{
    
static Singleton instance=null;

    Singleton()
    
{
    }


    
public static Singleton Instance
    
{
        
get
        
{
            
if (instance==null)
            
{
                instance 
= new Singleton();
            }

            
return instance;
        }

    }

}

4、如何创建项模板?
创建一个项模板需要完成以下几步:
    a、创建项模板的VSDIR文件 [ VSDIR文件的描述可以参见 http://msdn.microsoft.com/library/chs/default.asp?url=/library/chs/vsintro7/html/vxconvsdirfiles.asp
    b、创建VSZ文件(项目控件)[ VSZ文件的描述可以参见http://msdn.microsoft.com/library/chs/default.asp?url=/library/CHS/vccore/html/vclrfunderstandingprojectcontrolfiles.asp
    c、定制javascripts
    d、创建文件模板

下面就逐一展开。 
     
    创建VSDIR文件

    -打开文件夹<Program Files>/Microsoft Visual Studio .NET 2003/VC#/CSharpProjectItems/LocalProjectItems/Code
    打开code.vsdir文件,并在其中添加如下内容: 
    ../../CSharpAddSingletonClassWiz.vsz|{FAE04EC1-301F-11d3-BF4B-00C04F79EFBC}|Singleton类|11|Singleton类|{FAE04EC1-301F-11d3-BF4B-00C04F79EFBC}|4515|0|SingletonClass.cs
    * 注意:
    以上内容不要换行。这个文件格式定义见VSDIR文件描述
    其中CSharpAddSingletonClassWiz.vsz是指所使用的vsz文件(项目控件)的位置。 
    如后面的图中显示的,添加此内容后Singleton类模板将出现在“本地项目项”的“代码”分支下。如果需要在“本地项目项”下也显示此“Singleton类”模板,则需要在<Program Files>/Microsoft Visual Studio .NET 2003/VC#/CSharpProjectItems/LocalProjectItems目录下的LocalProjectItems.vsdir文件中添加:../CSharpAddSingletonClassWiz.vsz|{FAE04EC1-301F-11d3-BF4B-00C04F79EFBC}|Singleton类|11|Singleton类|{FAE04EC1-301F-11d3-BF4B-00C04F79EFBC}|4515|0|SingletonClass.cs

    创建VSZ文件
    -打开文件夹<Program Files>/Microsoft Visual Studio .NET 2003/VC#/CSharpProjectItems
        创建文件CSharpAddSingletonClassWiz.vsz,在其中添加如下内容:
    VSWIZARD 7.0
    Wizard=VsWizard.VsWizardEngine.7.1
    Param="WIZARD_NAME = CSharpAddSingletonClassWiz"
    Param="WIZARD_UI = FALSE"
    Param="PROJECT_TYPE = CSPROJ"
    *注意:VSZ文件格式定义见VSZ文件描述
    其中比较重要的是Param="WIZARD_NAME = CSharpAddSingletonClassWiz",这里“CSharpAddSingletonClassWiz”是指定了当创建Singleton类时使用的向导名称。 

    定制javascripts

    打开目录<Program Files>/Microsoft Visual Studio .NET 2003/VC#/VC#Wizards
    新建一个名为CSharpAddSingletonClassWiz的目录,这个名称是和Param="WIZARD_NAME = CSharpAddSingletonClassWiz"中WIZARD_NAME对应的。
    打开这个目录,创建目录Scripts,然后再在Scripts下创建目录1033。然后创建default.js文件。在其中放置如下代码:
    
function OnFinish(selProj, selObj)
{
    
var oldSuppressUIValue = true;
    
try
    {
        
var strTarget = wizard.FindSymbol("ITEM_NAME");
        
var strClassName = strTarget.split(".");
        
var bValid = wizard.ValidateCLRIdentifier(strClassName[0]);
        
if (!bValid)
        {
            wizard.ReportError();
            
return VS_E_WIZARDBACKBUTTONPRESS;
        }
        oldSuppressUIValue 
= dte.SuppressUI;
        
var strProjectName     = wizard.FindSymbol("PROJECT_NAME");
        
var strSafeProjectName     = CreateSafeName(strProjectName);
        wizard.AddSymbol(
"SAFE_PROJECT_NAME", strSafeProjectName);
        SetTargetFullPath(selObj);
        
var strProjectPath    = wizard.FindSymbol("TARGET_FULLPATH");
        
var strTemplatePath     = wizard.FindSymbol("TEMPLATES_PATH");

        
var strTpl = "";
        
var strName = "";
        
var InfFile = CreateInfFile();

        AddReferencesForClass(selProj);
        AddFilesToCSharpProject(selObj, strProjectName, strProjectPath, InfFile, 
true);
    }
    
catch(e)
    {
        
if( e.description.length > 0 )
            SetErrorInfo(e);
        
return e.number;
    }
    
finally
    {
           dte.SuppressUI 
= oldSuppressUIValue;
           
if( InfFile )
            InfFile.Delete();
    }
}

function SetFileProperties(oFileItem, strFileName)
{
}

    *注意: 在这个JS文件中出现的方法调用可以在路径<Program Files>/Microsoft Visual Studio .NET 2003/VC#/VC#Wizards/2052下的common.js中找到,其中有比较清楚的注释说明。
    
    创建文件模板

    转到路径:<Program Files>/Microsoft Visual Studio .NET 2003/VC#/VC#Wizards/CSharpAddSingletonClassWiz,创建目录Templates,再在Templates目录下创建目录1033。目录创建完毕后添加文件Templates.inf,内容是:File1.cs(这个File1.cs是指我们所使用的文件模板名称)。随后创建文件File1.cs,根据前面给出Singleton模式示例的格式添加以下代码:
    
namespace [!output SAFE_NAMESPACE_NAME] 
{
    
using System;
    
/// <summary>
    
/// [!output SAFE_CLASS_NAME].
    
/// </summary>

    class [!output SAFE_CLASS_NAME] 
    
{
        
成员
        
构造函数
    }

}

    
好了。通过以上的步骤就完成了一个项模板的定制。
当我们再打开一个项目,选择“添加新项”时,会发现在本地项目项中多了一个"Singleton类"的模板。如图:

同时在“本地项目项”的分支“代码”中也可以看到“Singleton类”模板。
当选定打开后并查看代码,可以发现所创建的类实现前面说描述的Singleton模式。

OK。至此,如何来自定义项模板就基本清楚了。进而通过这种方式,我们可以尝试自定义项模板的集合,例如可以把常用的一些模式实现作成项模板,这样无疑会对开发效率的提高有所帮助!

BTW:刚刚发现这篇点缀自定义VS.NET2003有所重复,呵呵~ 
 

创建自定义的Visual Studio项模板

关键词: VisualStudio 模板 VSDIR    VIZ 目的:     创建自己的Visual Studio类模板,以创建实现单例模式(Singleton)的类为例。 1、何为模板?   ...
  • i_like_cpp
  • i_like_cpp
  • 2005年01月30日 10:51
  • 2213

为Visual Studio添加项目模板及项模板

1 问题的引入在做项目的时候,需要代码规范,版本信息不可或缺,但是每次在文件头COPY版本信息很麻烦,而且也不太容易控制。为了更好、更规范的去完成项目,需对项目文件做统一的格式来处理。 2 环境描述O...
  • qiaozhiwei
  • qiaozhiwei
  • 2009年12月15日 22:44
  • 20944

用Visual studio 创建自定义控件

想了解一下自定义控件的知识,不过,在自
  • haoyujie
  • haoyujie
  • 2014年04月17日 17:22
  • 2332

Visual Studio 添加自定义菜单

VS中添加自定义菜单除了使用扩展插件外,还可以使用外部工具,本文介绍的就是使用外部工具添加自定义菜单。添加外部工具 在vs顶部菜单中依次选择:工具-外部工具 点击添加按钮即可添加一个外部的exe工具,...
  • xy109
  • xy109
  • 2016年08月15日 09:38
  • 528

vs2015 自定义类模板的方法

第一步:找到模板文件 路径:C:\Program Files (x86)\Microsoft Visual Studio 14.0\Common7\IDE\ItemTemplates\CSharp\...
  • new_smile
  • new_smile
  • 2016年08月04日 11:05
  • 3344

visual studio 自定义 关键字

有时后,特别希望能够让某些字定义关键字能够在editor里面被highlight.  这个时候, 最简单的办法是1)创建一个叫做usertype.dat,  放在C:/Program Files/Mi...
  • zifuyang
  • zifuyang
  • 2007年06月23日 03:32
  • 793

一分钟了解"自定义安装visual studio 2010以节省硬盘空间"

visual studio 2010中很多部件是用不到的,不如不装,还能节省空间.所以选择自定义安装的时候可以除了vc++那一项 以及 graphic 那一项,其他的都可以不安装. graphics...
  • yes1989yes
  • yes1989yes
  • 2017年08月24日 11:08
  • 122

Visual Studio 自定义项目模板

经常我们需要新建一个项目,然后新建我们的View文件夹,ViewModel文件夹,Model文件夹,还有把我们的ViewModelBase放入我们的VIewModel,如果还用框架,还需要加上好多。而...
  • lindexi_gd
  • lindexi_gd
  • 2016年11月02日 10:46
  • 1625

visual studio 2008 自定义头文件设置

以前玩单片机的时候,.c文件和.h文件都是一堆丢在一个文件夹里面,一起编译,这样自定义的头文件通过#include“”来包含,在当前路径下就可以自动搜索到。当然这样虽然方便,但是一大堆源文件和头文件放...
  • shan275
  • shan275
  • 2016年05月07日 14:51
  • 1099

【转载】 Visual Studio插入自定义代码段

一直想找个快捷键,是可以自定义插入代码段的,今天看到一篇文章。 原文:http://developer.51cto.com/art/201006/208136.htm 创建自定义代码段 ...
  • gjban
  • gjban
  • 2015年10月14日 18:40
  • 1029
收藏助手
不良信息举报
您举报文章:创建自定义的Visual Studio项模板
举报原因:
原因补充:

(最多只允许输入30个字)