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

The Archive Base Latest Questions

Editorial Team
  • 0
Editorial Team
Asked: May 16, 20262026-05-16T12:20:21+00:00 2026-05-16T12:20:21+00:00

Why is this piece of code not working on Chrome 4.0 but works on

  • 0

Why is this piece of code not working on Chrome 4.0 but works on FF 3.5. The problem that occurs is the selector $(‘li#node-‘+nodes[i].id +”).append function is not working in chrome but is working fine in firefox. Is there a problem with appending to DOM elements that have been created on runtime in Chrome? Should I use Jquery.live() ?


   $.getJSON("/data/all" , function(data){
                    nodes = data;
                    len = nodes.length;
    for(i=0; i<len; i++){
                        if(i==0){
                           // works on FF && Chrome
                           $('ul#root').append('<li id="node-'+ nodes[i].id +'"><input type="checkbox" name="">'+ nodes[i].name); 

                           // works on FF only
                          $('li#node-'+nodes[i].id +'').append('<ul id="' + nodes[i].id +'>'); 

                        }
                         else{
                           ...   
                           ... 
                        }
  • 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-16T12:20:22+00:00Added an answer on May 16, 2026 at 12:20 pm

    Your HTML was invalid, and Chrome did not accept it. Firefox was more lenient in what it allowed. Whenever there are lots of quote openings and closings because of a dynamic value, it’s better to use the object style element creation in jQuery rather than doing it all in a string. The problem is with this line:

    $('li#node-'+nodes[i].id +'').append('<ul id="' + nodes[i].id +'>');
    

    The output ul it produces is (notice the missing quote):

    <ul id="1>
    

    For creating complex selectors, it is much better to use string replacement:

    var li = "li#node-{id}".replace("{id}", nodes[i].id);
    

    To create elements with dynamic attributes, use objects to initialize:

    var ul = $('<ul>', {
        id: nodes[i].id
    });
    

    The code below although a little verbose and maybe a little slow is hard to get wrong especially in a language like JavaScript where a missing quote can do havoc as we just witnessed.

    var li = "li#node-{id}".replace("{id}", nodes[i].id);
    var ul = $('<ul>', {
            id: nodes[i].id
        });
    $(li).append(ul);
    
    • 0
    • Reply
    • Share
      Share
      • Share on Facebook
      • Share on Twitter
      • Share on LinkedIn
      • Share on WhatsApp
      • Report

Sidebar

Related Questions

I just realized that this piece of code works well in Firefox but not
I have this particular piece of code, but its not working. text = text.Replace(\xEF\xBF\xBD,
I have this piece of code that does not work: public CartaoCidadao() { InitializeComponent();
This piece of code used to work in MVC 1 but it does not
I have this piece of code, which is not working: BigInteger sum = BigInteger.valueOf(0);
I don't understand why this piece of code is not working. Only backspace and
Why this piece of code is working on my fsi, but can't build the
I'm just wondering why this piece of code is not working. I don't have
this piece of code worked fine on my machine, but it doesn't on my
I have the following piece of code which is not working the way I

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.