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 8381181
In Process

The Archive Base Latest Questions

Editorial Team
  • 0
Editorial Team
Asked: June 9, 20262026-06-09T16:38:22+00:00 2026-06-09T16:38:22+00:00

Given an array mapped in knockout.js and using custom templates , how can one

  • 0

Given an array mapped in knockout.js and using custom templates, how can one have each item in the array rendered using a different template?

Here is a link to an example on jsFiddle of the desired functionality – somewhat as one would hope it would be.

In simple terms, given an array like this:

people: ko.observableArray([
    { name: 'Rod', age: 123, template: 'personItem' },
    { name: 'IBM', incorporated: 1911, template: 'corporateItem' },
])

How can one set up a foreach: binding that uses one template for some items, and different templates for others.

(Note: I am aware that the use of underscore templates somewhat conflates the issue in question, and apologize for any unnecessary confusion.)

I have thought about using one template with a set of if bindings – one for each template type, like this:

<div data-bind='foreach: people'>
   <div data-bind='if: people.template() == "personItem"'>
   </div>
   <div data-bind='if: people.template() == "corporateItem"'>
   </div>
</div>

This seems quite inelegant, and I suspect (hope) there is a more elegant and fairly straightforward option.

Any thoughts would be greatly appreciated & thanks for reading.

  • 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-09T16:38:23+00:00Added an answer on June 9, 2026 at 4:38 pm

    Rather than passing a string to the name parameter of the template binding, you can actually pass a function to determine the template. You would have to combine this with using the foreach option in your case rather than doing an “each” through your items.

    So, your view model would look like:

    var viewModel = {
        people: ko.observableArray([
            { name: 'Rod', age: 123, template: 'personItem' },
            { name: 'IBM', incorporated: 1911, template: 'corporateItem' },
        ]),
        getTemplate: function(item) {
            return item.template;   
        }
    };
    

    and your mark up would be like:

    <ul data-bind="template: { name: getTemplate, foreach: people }"></ul>
    
    <script type="text/html" id="personItem">
            <li>
                <b data-bind="text: name"></b> is <%= age %> years old
            </li>
    </script>
    
    <script type="text/html" id="corporateItem">
            <li>
                <b data-bind="text: name"></b> is <%= incorporated %> years old
            </li>
    </script>
    

    Here is an example: http://jsfiddle.net/rniemeyer/xF2xe/

    Here is some additional reference material:

    • http://www.knockmeout.net/2011/03/quick-tip-dynamically-changing.html

    • http://knockoutjs.com/documentation/template-binding.html#note_4_dynamically_choosing_which_template_is_used

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

Sidebar

Related Questions

This problem is taken from interviewstreet.com Given array of integers Y=y1,...,yn, we have n
Given an Array A of n subArrays Sn, how can I select the Array
Given an array of ids $galleries = array(1,2,5) I want to have a SQL
Given an array. How can we find sum of elements in index interval (i,
We gave a given array which can be in 4 states. array has values
I have the array variable say $value, and it has the below given array
How can I limit the amount of loops through an array using Smarty? Let's
I have the following script that dumps a given array's contents function dump(obj) {
How can I create a class with a given array of arguments to be
Given an array find the next smaller element in array for each element without

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.