Sign Up

Sign Up to our social questions and Answers Engine to ask questions, answer people’s questions, and connect with other people.

Have an account? Sign In

Have an account? Sign In Now

Sign In

Login to our social questions & Answers Engine to ask questions answer people’s questions & connect with other people.

Sign Up Here

Forgot Password?

Don't have account, Sign Up Here

Forgot Password

Lost your password? Please enter your email address. You will receive a link and will create a new password via email.

Have an account? Sign In Now

You must login to ask a question.

Forgot Password?

Need An Account, Sign Up Here

Please briefly explain why you feel this question should be reported.

Please briefly explain why you feel this answer should be reported.

Please briefly explain why you feel this user should be reported.

Sign InSign Up

The Archive Base

The Archive Base Logo The Archive Base Logo

The Archive Base Navigation

  • SEARCH
  • Home
  • About Us
  • Blog
  • Contact Us
Search
Ask A Question

Mobile menu

Close
Ask a Question
  • Home
  • Add group
  • Groups page
  • Feed
  • User Profile
  • Communities
  • Questions
    • New Questions
    • Trending Questions
    • Must read Questions
    • Hot Questions
  • Polls
  • Tags
  • Badges
  • Buy Points
  • Users
  • Help
  • Buy Theme
  • SEARCH
Home/ Questions/Q 7743719
In Process

The Archive Base Latest Questions

Editorial Team
  • 0
Editorial Team
Asked: June 1, 20262026-06-01T09:36:25+00:00 2026-06-01T09:36:25+00:00

I would like to store different objects in the same controller content array and

  • 0

I would like to store different objects in the same controller content array and render each one using an appropriate view template, but ideally the same view.

I am outputting list objects using the code below. They are currently identical, but I would like to be able to use different ones.

<script type="text/x-handlebars">
  {{#each App.simpleRowController}}
    {{view App.SimpleRowView class="simple-row" contentBinding="this"}}
  {{/each}}
</script>

A cut-down version of the view is below. The other functions I haven’t included could be used an any of the objects, regardless of model. So I would ideally have one view (although I have read some articles about mixins that could help if not).

<script>
  App.SimpleRowView = Em.View.extend({
    templateName: 'simple-row-preview',
  });
</script>

My first few tests into allowing different object types ended up with loads of conditions within ‘simple-row-preview’ – it looked terrible!

Is there any way of dynamically controlling the templateName or view used while iterating over my content array?

UPDATE

Thanks very much to the two respondents. The final code in use on the view is below. Some of my models are similar, and I liked the idea of being able to switch between template (or a sort of ‘state’) in my application.

<script>
  App.SimpleRowView = Em.View.extend({
    templateName: function() {
      return Em.getPath(this, 'content.template');
    }.property('content.template').cacheable(),
    _templateChanged: function() {
      this.rerender();
    }.observes('templateName'),
    // etc.
  });
</script>
  • 1 1 Answer
  • 0 Views
  • 0 Followers
  • 0
Share
  • Facebook
  • Report

Leave an answer
Cancel reply

You must login to add an answer.

Forgot Password?

Need An Account, Sign Up Here

1 Answer

  • Voted
  • Oldest
  • Recent
  • Random
  1. Editorial Team
    Editorial Team
    2026-06-01T09:36:27+00:00Added an answer on June 1, 2026 at 9:36 am

    You can make templateName a property and then work out what template to use based on the content.

    For example, this uses instanceof to set a template based on the type of object:

    App.ItemView = Ember.View.extend({
        templateName: function() {
            if (this.get("content") instanceof App.Foo) {
                return "foo-item";
            } else {
                return "bar-item";
            }
        }.property().cacheable()
    });
    

    Here’s a fiddle with a working example of the above: http://jsfiddle.net/rlivsey/QWR6V/

    • 0
    • Reply
    • Share
      Share
      • Share on Facebook
      • Share on Twitter
      • Share on LinkedIn
      • Share on WhatsApp
      • Report

Sidebar

Related Questions

I would like to store the cookies from one open-uri call and pass them
I would like to store very large sets of serialized Ruby objects in db
I would like to have an array dynamically generated by keypress, then have different
I have a certificate .p12 and .crt and I would like store the public
I would like to store large dataset generated in Python in a Django model.
I would like to store lengthy .sql scripts in my solution and execute them
I would like to store a list of entityIDs of outlook emails to a
I would like to store files in a specific directory inside the documents directory,
I would like to store 2010-03-26 10:13:04 Etc/GMT value in column of type datetime.
I would like to store only .txt filenames from a specific dir (let's say:

Explore

  • Home
  • Add group
  • Groups page
  • Communities
  • Questions
    • New Questions
    • Trending Questions
    • Must read Questions
    • Hot Questions
  • Polls
  • Tags
  • Badges
  • Users
  • Help
  • SEARCH

Footer

© 2021 The Archive Base. All Rights Reserved
With Love by The Archive Base

Insert/edit link

Enter the destination URL

Or link to existing content

    No search term specified. Showing recent items. Search or use up and down arrow keys to select an item.