最近基于ExtJs和asp.net mvc做了一个系统.来总结下.一起讨论下.

一.技术分析


1.web数据传输

ExtJS作为前端UI展现层,传输数据格式为json或者xml,一般大部分为json.

2.asp.net mvc

(不要考虑太多mvc其他特性,controller+method就够了)的和路由url很好的符合了这一要求,实现起来很轻松.

3.选一款依赖注入容器

只要你好好学过一款Ioc组件,概念都还是一样的,做法不同而已,我选的是微软的Unity,

这里我并没有把Service配置在xml中,根据我的理解,大部分软件并不需要这么灵活,我就纯注册就够了(其实往往是这样,我们可以问问自己,我们用到了多少功能).因为大部分都是注册一次,永不修改的…真的有必要的时候可以提出

image

Ioc组件很多,个人认为比较强大的还是spring.net,功能非常丰富,还有AOP功能,最主要的是其可以和其他组件结合的很好.

容器作为底层服务,主要就是为我们提供灵活性.想办法与现有组件结合,注册相关服务.

4.数据库操作(NHibernate)

3年前我会选ADO.NET

2年前我选Microsoft.Practices.Data.Application

1年前我选linq to sql

现在我选nhibernate

关于NHibernate映射

(1)若你是初学者,乖乖的自己手动配吧
(2)若你喜欢linq的,有一款FluentNHibernate可供选择(用新技术请考虑风险,玩的没关系)
(3)若你映射配置文件玩的很熟悉了,就用NHibernate.Mapping.Attributes挂标签自动生成吧(不推荐用什么代码生成器,都是要重新改的)

 

5.比较java web经典平台

比较庆幸,之前有接触过java,java的web编程架构很稳定,3年前如此,现在还是一样,不同的只是版本升级而已,这点.net程序员比较惨的.这也见证了spring,hibernate,struts(webwork)在目前而言是最好的拍档.

换成.net平台也就是spring.net(Ioc容器)+nhibernate(orm)+asp.net mvc

spring.net和nhibernate都属于java移植产品,所以应该来说资料是非常的多,想学习的人,应该把眼光放到java社区中,收获会很多的,稍微比较下c#和java语言就好了(千万别学了就跑去学java了:)).

asp.net mvc对比struts而言,方便了很多,但不同的是java附产品比较多,像asp.net mvc这样的框架,java也有些框架已经开始改进了(看到过,基本上理念是一样的).

当然这里均采用的开源路线,大家也可以采用微软自家平台的技术.

二.技术串联

 

1.注册容器

2.初始化Nhibernate

image

我们都知道Ioc是可以与asp.net mvc结合的

image

3.Nhibernate与容器配合法

(1)Nhibernate与spring.net的结合,这里已经有经典例子在了,何谓经典例子,就是大家都这么干,而且也没出什么问题,我也就这么干,确实有点道理的…虽然有时候真不懂为什么这么干。。。呵呵
(2)用单例的方式在应用启动时注册,如上法
(3)Nhibernate若映射换FluentNHibernate的话,或者加入linq to nh,则整个设计就要重新考虑了

我想上面的设计有点意思,特别是加入了linq to nh我的设想是这样的

(1)简单查询用linq to nh
(2)hql主打,标准查询辅助…
(3)若由于对nh框架不熟,导致查不出来,或者遇到速度慢,先上t-sql(原因一般都是自身学的不好造成的,先怀疑自己,怀疑不下去了再去怀疑框架本身…)

三.项目细分

 

这里忽略分布式应用,我没具体搞过…

  1. Entity项目一个
  2. Service接口项目一个
  3. Service接口默认实现项目一个
  4. Domain项目一个
  5. 主体辅助类项目一个(放杂七杂八用的)
  6. 测试项目一个(可选)
  7. web相关项目一个(放与web相关的和controller)
  8. web主打项目一个(运行项目,主放js用…)


基本上最基本的就是这样,你可以细分,也可以把上面很多项目合并为同一项目.

若想灵活就多用反射与配置文件

四.细化

若要完成一般的数据增删改系统的话,我们还可以稍微细化封装,这样的封装是很方便的.

1.没有绝对的灵活,需要一定的耦合,ext框架对于后端请求的json数据有一定要求,所以数据转换在所难免,所以准备一些通用的数据类型转换的功能

2.对于千篇一律的数据增删改,若无特殊的业务逻辑,可考虑借助asp.net mvc和反射功能完成,这样一个controller的设计可以代替很多个.

3.在传json时勿使用延迟加载等特性.

4.一个hql配置系统,不要因为某一查询条件改了而重新编写代码,可以考虑做个机制,把hql语句提取出来

5.巧用nhibernate拦截机制,日志必不可少

6.一套稳定的权限机制

7.对于ext,要有一套js加载机制

总结起来细化的都是对于不同需求而变化设计的.

 

如果不是很难的项目,花一段时间实践,这种搭配很容易学会.

接下来重点还是回到.net framework来学习.

个人见解...大家有什么高见发表下

Logo

权威|前沿|技术|干货|国内首个API全生命周期开发者社区

更多推荐