本文整理自网络。
web site是新建一个网站,web application是asp.net应用程序,大体上二者没太大区别。web application是visual studio 2005之前就有的,web site是后来新加的。两者的区别如下:
WebApplication编程模型的优点:
●网站编译速度快,使用了增量编译模式,仅仅只有文件被修改后,这部分才会被增量编译进去。
●生成的程序集
WebSite:生成随机的程序集名,需要通过插件WebDeployment才可以生成单一程序集
WebApplication:可以指定网站项目生成单一程序集,因为是独立的程序集,所以和其他项目一样可以指定应用程序集的名字、版本、输出位置等信息
●可以将网站拆分成多个项目以方便管理
●可以从项目中和源代码管理中排除一个文件
●方便的支持VSTS的Team
●更强大的代码检查功能,并且检查策略受源代码控制
●可以对编译前后进行自己规定的处理
●对App_GlobalResources
●直接升级使用VS2003构建的大型系统
WebSite编程模型的优点:
●动态编译该页面,马上可以看到效果,不用编译整个站点(主要优势)
●同上,可以使错误的部分和使用的部分不相干扰(可以要求只有编译通过才能签入)
●可以每个页面生成一个程序集(一般不会采用这种方式)
●可以把一个目录当做一个Web应用来处理,直接复制文件就可以发布,不需要项目文件(适合小站点)
●可以把页面也编译到程序集中(应该用不到,而且WebApplication也可以通过WebDeployment插件来实现)
两种编程模型的互相转换:
VS2005
只需要复制文件,右键执行“转换为Web应用程序”即可。
未查到有专门的反向转换工具,但比较后发现如果转换也非常简单。
删除所有*.designer.cs
将*.aspx、*.ascx、*.master页面文件中的
这样就可以转换回来了
Scenario
|
Web Application Project
|
Web Site Project
|
Project definition
|
跟
|
一个目录结构就是一个
WEB
项目。没有项目文件存在。这个目录下的所有文件,都被作为项目的一部分而存在。 我们实际部署的一个网站,部署上当然不会有任何项目文件存在,如果你想对这个网站进行修改,用这种编程模型就非常适合。我们根本不用在乎这个 WEB 站点中,那些文件属于哪个项目。 |
编译和生成
|
跟
Visual Studio .NET 2003
的
Web
应用项目编译模式几乎一样。
项目中的所有的
code-behind
例如:
Model-View-Controller (MVC) |
编译(Build
)命令仅仅是测试这个
WEB
站点是否编译正确,调试一个
WEB
站点项目的时候,是通过依赖你的源代码文件,
ASP.net
进行动态编译页面和类来实现的。
预编译站点和动态编译站点用的是同一个
ASP.net
batch
fixed-names
|
Iterative development |
调试或者运行
Web
页面的时候,你必须全部编译整个
WEB
项目。
编译整个
WEB
项目通常比较快,因为
Visual Studio
使用了增量编译模式,仅仅只有文件被修改后,这部分才会被增量编译进去。
|
你可以配置
Visual Studio 2005
的编译属性:编译整个站点、编译一个指定页面、或者什么都不作。在最后一种情况下,当你运行一个
WEB
站点的时候,
Visual Studio
仅打开一个浏览器,并访问当前或者起始页,当这个请求被发送后,
ASP.net
这种模式下,页面被动态编译或者被编译成不同应用程序集,所以如果你调试或者运行一个页面的时候,不需要整个项目被编译通过。有错误的部分跟你使用的部分可以互不干扰。
默认情况下,当你运行或调试任何
WEB
页的时候,
Visual Studio
完全编译
Web Site
项目。
这么做可以看到编译时的所有错误。但是,在开发进程中,完全编译整个站点会是相当慢的。所以推荐你在开发调试中,只编译当前页。
|
部署
|
因为所有的类文件被编译成一个应用程序集,当你部署的时候,只需要把这个应用程序集和
这种模型下,
.aspx
不过,如果你使用
Web Deployment Projects (
一个
Visual Studio 2005
的插件,没有被默认包含到
VS2005
中
),
你就可以把
.aspx
如果你只修改了小小的一行代码,你也需要把整个项目的所有代码都编译,并且发布包含所有代码的这个应用程序集。
|
使用
Visual Studio
最新版本的
默认是在
Bin
目录下预编译成几个应用程序集,典型的是一个目录对应一个应用程序集。
fixed-names |
从
Visual Studio .NET 2003
升级
|
因为跟
VS2003
采用了一样的
WEB
项目开发模型,升级是非常非常简单的。
|
Web site
虽然微软提供了一个转换向导,但是如果你的项目如果是一个复杂的
VS2003
项目,使用这个转换向导后,你还需要对照转换手册,做很多工作。
如果你要从
VS2003
升级,建议不要用这种
WEB
站点开发模版。而是使用
Web application |
Option or Task
|
Web Application Projects
|
Web Site Projects
|
你有一个大型的
Visual Studio .NET 2003 Web
应用需要迁移到
VS2005
。
|
√
|
|
喜欢使用
|
|
√
|
喜欢采用下面的方式编写网站:
|
|
√
|
在编写页面时候,为了可以快速的看到编写效果,动态编译该页面,马上可以看到效果,不用编译整个站点。
| ||
(就是说,只需要保存文件,然后在浏览器中刷新一下,就可以看到自己刚刚做的效果)
| ||
需要控制编译后应用程序集的名字
|
√
|
|
需要每个页面产生一个应用程序集
|
|
√
|
WEB
页面或者
WEB
用户控件中需要使用到单独的类。
|
√
|
|
需要使用多个
Project
来构建一个
Web
应用。
|
√
|
|
需要处理
pre-build |
√
|
|
希望把一个目录当作一个
WEB
应用来处理,而不需要新建一个
Project |
|
√
|