• Home

  • Custom Ecommerce
  • Application Development
  • Database Consulting
  • Cloud Hosting
  • Systems Integration
  • Legacy Business Systems
  • Security & Compliance
  • GIS

  • Expertise

  • About Us
  • Our Team
  • Clients
  • Blog
  • Careers

  • CasePointer

  • VisionPort

  • Contact
  • Our Blog

    Ongoing observations by End Point Dev people

    Unbalanced HTML considered harmful for jQuery

    Jeff Boes

    By Jeff Boes
    January 20, 2014

    This isn’t earth-shattering news, but it’s one of those things that someone new to jQuery might trip over so I thought I’d share.

    I had a bad experience recently adding jQuery to an existing page that had less than stellar HTML construction, and I didn’t have time nor budget to clean up the HTML before starting work. Thus, I was working with something much more complex than, but equally broken as what follows:

    <table><tr><td>
    <form>
    </td></tr>
    <tr><td>
    <input type="text">
    </form>
    </td></tr></table>
    

    The jQuery I added did something like this:

    $('form input').css('background-color: red');
    

    and of course, I was quite puzzled when it didn’t work. The pitfall here is that jQuery may or may not be able to handle misconstructed or unbalanced HTML, at least not as well as your average browser, which will shift things around internally until something makes sense to it. The minimal solution is to move the opening and closing “form” tags outside the table.

    javascript jquery


    Comments