140
votes

I've come across something called Prism a lot recently. Microsoft, who run the project, describe it as

Guidelines for composite applications in WPF and Silverlight.

Even after reading the more detailed descriptions out there, I have next to no clue what it's actually about, I'm afraid.

I'm hoping here that someone could give me a clear succinct explanation of what Prism actually is and why I should learn it. I have been a WPF developer for a couple of years now, used MVVM my fair share, and have lately encountered people using Prism, but personally feel a bit out of the loop here.

In particular, I'm wondering about the following points:

  • Is Prism literally just (or mainly) a booklet, as given on the MSDN site? Does it include any libraries, if so for what exactly?

  • Is Prism an MVVM framework? Should I be using it as the "official Microsoft MVVM framework" over others out there or my own?

  • Does it provide dependency injection? Does it relate to MEF at all in this way?

  • Anything else I should know about what Prism does, as a WPF/Silverlight developer.

2
It's actually a fairly complex thing, too - Prism tries to fill a lot of needs, so it's tough to get a single "right" answer if you're trying to figure out its purpose. It really does multiple things.Reed Copsey
This similar question asked by me is also having some good answers to this question - stackoverflow.com/questions/6251821/…akjoshi
yet another murky quagmire from P&P. every time they release something like this I find myself having to go to SO or wikipedia to find out what the thing actually is. why does it always have to be so cryptic?Adam Ralph
if you like, it is a kind of documentation that guide you to how implement MVVM pattern in your WPF/Silverlight applications. there is also a library from codePlex which i am not sure what is it exactly for. a good documentation about PRISM lives in below link, it worth if have a look at it: Prism 4.1 - Developer's Guide to Microsoft Prism - MSDNuser3353518

2 Answers

94
votes

Prism is the Microsoft Patterns and Practices Team official guidance for building "composite applications" in WPF and Silverlight.

Its intended to provide guidance on the best practices for building large scale applications which are flexible in terms of development and maintainability.

This includes guidance on dependency injection (via Unity or MEF), layout (including using MVVM), composite event handling, etc.


Is Prism literally just (or mainly) a booklet, as given on the MSDN site? Does it include any libraries, if so for what exactly?

It is a book, but also includes the libraries for support (on the GitHub site).

Is Prism an MVVM framework? Should I be using it as the "official Microsoft MVVM framework" over others out there or my own?

Yes and no. It includes guidance for using MVVM, but is far more than an MVVM framework. It's really not, in and of itself, an "MVVM framework" - though it does include MVVM guidance.

Does it provide dependency injection? Does it relate to MEF at all in this way?

Yes. It originally included Unity, but the latest release includes using MEF for DI.

Anything else I should know about what Prism does, as a WPF/Silverlight developer.

It's worth taking a look at how they do things. They have a very elaborate "region" concept, as well as good event aggregation support. It also includes good practices for developing against WPF, Silverlight, and Windows Phone simulataneously.

19
votes

It's a framework for building WPF and Silverlight apps.

http://compositewpf.codeplex.com/

It used to be called "Prism" before Microsoft renamed it to "CompositeWPF."

Answers:

1) Prism is an MVVM framework to use as a foundation for your applications

2) I suggest so depending on your specific requirements. You should post another question with specific details so you can get some specific answers.

3) Prism uses dependency injection (Unity) but does not "provide" it

4) Imo, Prism provides a lot of functionality but is heavy on the learning curve. For small projects with you as the sole developer, you may not need the abstraction and tools that it provides.