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

The Archive Base Latest Questions

Editorial Team
  • 0
Editorial Team
Asked: May 22, 20262026-05-22T00:38:23+00:00 2026-05-22T00:38:23+00:00

We have a CMS that likes to insert inline styles, I have written some

  • 0

We have a CMS that likes to insert inline styles, I have written some code that removes the inline styles adds a class and rewrites the contents of the style attribute into a style tag in the head.

Example HTML

<html>
<head>
    <title>Title</title>
</head>
<body>
    <div id="container">
        <p style="width: 50%;">Blah blah blah</p>
        <p style="font-weight: bold;">Even more blah blah blah</p>
        <p>Can I get some blah blah blah</p>
        <p>Ooo Ahh blah blah blah</p>
    </div>
</body>
</html>

jQuery function

$.each($('#container [style]'), function(index, el){
    var cssText = el.style.cssText;
    var className = "auto-class-" + index;
    $(el).removeAttr("style");
    $(el).addClass(className);
    $("<style type='text/css'> ." + className + "{" + cssText + "} </style>").appendTo("head");
})

Desired Result HTML

<html>
<head>
    <title>Title</title>
    <style type="text/css"> .auto-class-1 { width: 50%; } </style>
    <style type="text/css"> .auto-class-2 { font-weight: bold; } </style>
</head>
<body>
    <div id="container">
        <p class="auto-class-1">Blah blah blah</p>
        <p class="auto-class-2">Even more blah blah blah</p>
        <p>Can I get some blah blah blah</p>
        <p>Ooo Ahh blah blah blah</p>
    </div>
</body>
</html>

I all the good browsers this works as expected, but in IE6 the jQuery [style] selector seems to grab all the elements inside the #container. So you get the following instead.

Result HTML in IE6

<html>
<head>
    <title>Title</title>
    <style type="text/css"> .auto-class-1 { width: 50%; } </style>
    <style type="text/css"> .auto-class-2 { font-weight: bold; } </style>
    <style type="text/css"> .auto-class-3 { } </style>
    <style type="text/css"> .auto-class-4 { } </style>
</head>
<body>
    <div id="container">
        <p class="auto-class-1">Blah blah blah</p>
        <p class="auto-class-2">Even more blah blah blah</p>
        <p class="auto-class-3">Can I get some blah blah blah</p>
        <p class="auto-class-4">Ooo Ahh blah blah blah</p>
    </div>
</body>
</html>

In the example above this doesn’t cause any issues but on our website where there are over 300 DOM nodes on any given page it’s a mess.

The question is how can I select only the DOM nodes with a style attribute in IE6.

Also is there an easy way to write all the rules into one style tag rather than having a separate style tag for each rule.

  • 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-22T00:38:23+00:00Added an answer on May 22, 2026 at 12:38 am

    This isn’t an answer to the specific question you asked, but it is what I think you should do.

    You said in a comment:

    It’s for print style sheets. The
    inline styles over overrule them, but
    style tags are fine.

    The solution you’re using (moving inline styles to <style> elements) is not very elegant.

    You’d be much better off adding !important to every single declaration in your print stylesheet.

    body {
        color: #444 !important;
        padding: 0 !important;
        margin: 0 !important;
    }
    #menu {
        display: none !important;
    }
    

    Yes, this is ugly, but it’s much cleaner than a JavaScript-based solution.

    If you’d like some background information:

    See: http://css-tricks.com/specifics-on-css-specificity/

    The !important value appended a CSS
    property value is an automatic win. It
    overrides even inline styles from the
    markup.
    The only way an !important
    value can be overridden is with
    another !important rule declared later
    in the CSS and with equal or great
    specificity value otherwise.

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

Sidebar

Related Questions

I have an application that I would like to embed inside our companies CMS.
I have a CMS that uses a syntax based on HTML comments to let
At my current job we have a CMS system that is .NET/SQL Server based.
We have a hosted site that has a CMS we built running on a
I'm building a CMS in PHP and one dread I have is that the
My goal is to have a CMS that is totally self-contained like a flat-file
I have a CMS system that stores data across tables like this: Entries Table
I have a project that adds elements to an AutoCad drawing. I noticed that
I have a script that appends some rows to a table. One of the
We have a CMS system that creates long URLs with many parameters. We 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.