Chinaunix首页 | 论坛 | 博客
  • 博客访问: 5464051
  • 博文数量: 671
  • 博客积分: 10010
  • 博客等级: 上将
  • 技术积分: 7310
  • 用 户 组: 普通用户
  • 注册时间: 2006-07-14 09:56
文章分类

全部博文(671)

文章存档

2011年(1)

2010年(2)

2009年(24)

2008年(271)

2007年(319)

2006年(54)

我的朋友

分类:

2007-10-15 16:23:44

插件可以封装一定的业务,同样控件也具有封装性。

可以说控件的出现大大简化了我们开发的工作量。作为一个插件系统来说,实现一个通用的插件能在更大粒度上进行复用。插件是比控件更加高层的一种模块封装方式。

插件和控件有相同的地方:封装和复用。本文分析了它们的异同,并且提出另外一个比较有趣的概念——伪插件。请大家继续往下读一读。

一、插件和控件的比较

发布

控件编译到系统中,和系统作为一个整体发布。

插件是在系统的运行过程中动态关联到系统上,可以和系统的其他部分保持物理上的隔离。

配置能力

控件在系统中的呈现方式在编译时已经确定,通过代码描述控件的表现形式,呈现位置等。

插件的呈现方式在运行的时候根据外部的配置文件指定。

功用

控件作为公用的组件使用,在我们编写业务模块时,控件作为基本资源被我们使用。

插件作为一个独立的业务模块存在,直接面向用户。

开发调试

控件的调试简单,但插件的调试却比较麻烦。正是因为为了灵活性而制造的隔离措施导致了调试上的困难。通常一个插件作为一个工程开发。

二、插件与控件的关系

插件是业务模块,就像上面所说的,在我们编写业务模块时控件作为基本资源被使用。所以插件与控件的关系如下图左所示,普通的业务模块如下图右所示。

可以看到,插件是满足一定接口协议的业务模块。

三、混乱的界限

作为控件使用的插件

如果一个插件中只有一个控件,并且没有其他的业务逻辑。这种情况下它是插件还是控件?

就像上面所说的,插件是带有一定业务的模块,并且是直接面向用户作为一个系统功能来体现的。插件仅仅是封装了一个控件,并没有带有其他的业务。像这种模块是作为其他插件的子插件使用。如下图所示。

这和我们上面看到的插件内部直接包含控件就不一样了。控件作为子插件的形式被其他插件使用。

插件的配置文件中会将自身的属性作为配置,如标题、图标、和其他一切可以作为配置的元素。但子插件没有详细的配置文件,它的属性直接通过插件的接口暴露给父插件。

这类的子插件是介于插件与控件之间的“伪插件”,因为它并不能独立地在系统中运行,并且通常情况下不带有业务逻辑,不能直接给用户带来价值。

发布后可更换控件

伪插件似乎没有什么好处,谁会无缘无故地在控件之上再封装一层作为插件来使用?

可以想象一下,在系统发布后,我们需要改变某些插件中使用的控件。当然,可以将那些插件全部重新编译后发布。但如果使用这种“伪插件”的思路,我们可以开发一个满足同样接口的另外一个伪插件,并在内部使用不同的控件实现。这样就可以在不发布其他插件的情况下,灵活地修改我们使用的控件了。

额外开销

如果所有的控件都像上面的来实现,那简直是一场恶梦,并且也没有这个必要。因为这样做的成本比较大。

至于实际中是直接用控件,还是用伪插件的技术,那就要看我们的决策了。

阅读(689) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~