Table of Contents

Data Streams (IDataStream)

you are here (click to zoom) - discover the stack

DataStreams are objects which behave like a table or a list. They deliver a bunch of content-items/Entities. Common examples in Razor-templates are:

  1. Data["Default"]
    This is a data-stream containing all content-items prepared for the template.
  2. App.Data["Tag"]
    This would be a data-stream containing all tag-items in the entire app, if the App has Tag items.
Tip

All DataSources have at least one Out-stream called Default. But they can have more streams as well.

Most DataSources also have one or more In streams providing data or configuration to that DataSource which will then give a modified list to the Out.

How to use

The most commen uses will loop through all items in such a stream and show them. Here's an example:

<ol>
  @foreach(var person in Data["Default"]){
    <li>@AsDynamic(person).FullName</li>
  }
</ol>

The @foreach will go through all the items. Each item is of the type IEntity. To make it easier to template, we convert it to a Dynamic Entity using AsDynamic and then we can just show the name with .FullName.

In most cases we will need the loop-item a lot, and would preferr to not write AsDynamic every time. Because of this, we usually write the AsList in the Loop, like this:

<ol>
  @foreach(var person in AsList(Data["Default"])) {
    <li>@person.FullName - born @person.Birthday and married to @person.SpouseName</li>
  }
</ol>
Discover More in the Razor Tutorials

We have an rich series of Razor tutorials. You should really check them out 👍.


Advanced Use Cases

There are some advanced use-cases where you need to know more about the IDataStream object, mostly when using LINQ. This is fairly rare, and if you really need to know more, it's best to consult the EAV DataSource code.

Just a few more details you might care about:

  1. The stream has a property Source which points to the owning DataSource.
  2. a stream might be attached to many targets for further processing or for templating, but the stream doesn't know about this
  3. you can always looup through items on the stream itself using LINQ, like
    var blues = Data["Default"].Where(x => AsDynamic(x).Category == "Blue"))
    see also Use LINQ with Dynamic Data in Dynamic Code

of course there's always quite a bit more to it, like auto-caching, but you usually don't need to understand all that.

Read also

History

  1. Introduced in 2sxc 01.00
  2. Multi-Language since 2sxc 02.00