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

The Archive Base Latest Questions

Editorial Team
  • 0
Editorial Team
Asked: June 9, 20262026-06-09T22:16:54+00:00 2026-06-09T22:16:54+00:00

I would like to render a view for a model when the model is

  • 0

I would like to render a view for a model when the model is first fetched but not on every change.

My setup is as follows:

var m = new $.model.Customer({id: customer});
var v = new $.view.GeneralEditView({el: $("#general"), model: m});
m.fetch();

Then in the view initialize I bind the change event to the render method to render when the model is loaded:

this.model.bind('change', this.render);

The problem is that the view then renders on every change. I’d like to only render after the fetch. Unfortunately I’m not aware of any event that’s fired after a fetch for a model other than change.

Is there something like ‘reset’ for collections that I can bind to?

EDIT:

Perhaps to put it more succinctly, for Backbone models is there a way to distinguish when a model is loaded from the server versus changed locally?

  • 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-09T22:16:56+00:00Added an answer on June 9, 2026 at 10:16 pm

    There are a bunch of different ways to approach this (these all assume var view = this; somewhere in your view code):

    • Call .fetch() with a one-time success callback:

      m.fetch({
          success: function() {
              view.render();
          }
      });
      
    • Bind to change but unbind in the handler:

      function handle() {
          view.render();
          view.model.off('change', handle);
      }
      this.model.bind('change', handle);
      
    • Use _.once to limit handler calls:

      this.model.bind('change', _.once(function() {
          view.render();
      }));
      
    • Use a .ready() pattern for your models – example here. I like this option in cases where multiple views need to know when the model is loaded, and when you need to want to be able to write the same code without worrying about whether your model is loaded yet. The downside of this is that it requires you to add a model method like .isFullyLoaded() to test every time; the upside is that using a test function, rather than setting a flag, allows models to be loaded in bulk as part of a collection without having to change your code.

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

Sidebar

Related Questions

I would like to attach a new model to a view and have the
I would like to re-render a list made using Marionette.ItemView when the corresponding model
I have a Post and Tag model. I would like to show the first
I would like to know how to render the new action of another controller
I would like to render a list of HTML links in ASP.NET MVC. Note
I would like to render the 3D volume data: Density(can be mapped to Alpha
I would like to render a constructions like: <a href='/home'>Home</a> <span class='active'>Community</span> <a href='/about'>About</a>
I have 2 arrays that I would like to render in a template, one
I'm using Java3D to render a three-dimensional scene. I would like to overlay a
I want to use libharu to render my documents to PDF. I would like

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.