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

The Archive Base Latest Questions

Editorial Team
  • 0
Editorial Team
Asked: May 26, 20262026-05-26T20:47:42+00:00 2026-05-26T20:47:42+00:00

I would like to have a view that is extended to several other views

  • 0

I would like to have a view that is extended to several other views depending on the type of the model.

var AnimalView = Backbone.View.extend({.....});
var DogView = AnimalView.extend({......});
var CatView = AnimalView.extend({.....});

But what I’d really like to do is have the AnimalView determine which species results:

var AnimalView = Backbone.View.extend({
 initialize : function(){
  if (this.model.get("species")=="dog"){this = new DogView({model:this.model});}
  if (this.model.get("species")=="cat"){this = new CatView({model:this.model});}   
 })
});

I realize this doesn’t work but it’s the idea that I would like to have.

I could do this :

if (pet.get("species")=="dog"){petVeiw = new DogView({model:pet})}
else if (pet.get("species")=="cat"){petVeiw = new CatView({model:pet})}

But I would like to isolate that logic in the parent view, namely AnimalView.

Any ideas on the best way to get this done?

  • 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-05-26T20:47:43+00:00Added an answer on May 26, 2026 at 8:47 pm

    I can’t think of a case where I see that pattern really. I’d say it’s much more common to see some kind of factory class is responsible for taking an object and deciding which other class to create to go with that object. But I don’t think it would be a parent class that would do that. It would typically be some other object that was just responsible for that mapping operation.

    So while there might be a hierarchy of:

    AnimalView
         |
         +-- DogView
         |
         +-- CatView
    

    another object would generate the appropriate one (obviously bad pseudo description):

    AnimalFactory
         AnimalView getViewForAnimal(animal)
    

    Backbone would definitely allow you to create a DogView and CatView that both inherited behavior from an AnimalView. Perhaps sharing a common el that they both map to, common events that are mapped, and they just use different templates or something. I just wouldn’t expect the parent class to be the one to do the instantiation of the sub-classes.

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

Sidebar

Related Questions

I have an app that have several views. In one view I would like
I have a view that I would like to populate data when the next
I have a custom View that I would like to embed in an WebView.
I have a video view that is full screen and would like to trigger
I would like to have a custom view in my application that consists of
I have a custom-made view that extends the View class. I would like 2
I would like to have a special sub-node that could be attached to other
I have a view that looks like this: http://whatever/Download/viaId/12345 And i would like to
I have extended View to build a custom widget. I would like to define
I have a view controller that has three scroll views as subviews. I would

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.