html2scss

0.8.7 • Public • Published

HTML to SCSS

Node.js module that parses HTML to Sass SCSS structure format.

An online implementation is on the GitHub Page.

Things to Note

The primary purpose of this project is proof-of-concept. Regardless, take the following into consideration if you decide to use this for serious internet business work:

  • The parser is a work in progress.
  • Output accurately represents the DOM.
  • You should follow SMACCS for scalability.

Getting Started

npm install -g html2scss
html2scss -i http://news.ycombinator.com

Options

-h, --help		this help message
-i, --input		input file or URL
-o, --output		[optional] output file
-C, --Classes		[optional] parse element class names
-I, --IDs			[optional] parse element IDs

Example

Command

$ html2scss -i 'input.html' -o output.scss -C -I

input.html

<!doctype html>
<html lang="en">
    <head>
        <title>Example</title>
    </head>
    <body class="home">
 
        <section class="nav">
            <nav>
                <ul>
                    <li><a href="#">Menu</a></li>
                    <li><a href="#">Contact</a></li>
                </ul>
            </nav>
        </section>
 
        <section class="main content">
            <article id="first">
                <header>
                    <h1>Article Title</h1>
                </header>
                <div class="content"></div>
                <footer>
                    Publish Date
                </footer>
            </article>
            <article id="second">
                <header>
                    <h1>Article Title</h1>
                </header>
                <div class="content"></div>
                <article></article>
                <footer>
                    Publish Date
                </footer>
            </article>
        </section>
 
    </body>
</html>

output.scss

html {
 
    head {
 
        title {
 
        }
 
    }
 
    body {
 
        &.home {
 
        }
 
        section {
 
            &.nav {
 
            }
 
            &.main {
 
            }
 
            &.content {
 
            }
 
            nav {
 
                ul {
 
                    li {
 
                        a {
 
                        }
 
                    }
 
                }
 
            }
 
            article {
 
                &#first {
 
                }
 
                &#second {
 
                }
 
                header {
 
                    h1 {
 
                    }
 
                }
 
                div {
 
                    &.content {
 
                    }
 
                }
 
                footer {
 
                }
 
                article {
 
                }
 
            }
 
        }
 
    }
 
}

MIT License

HTML to SCSS is freely distributable under the terms of the MIT license.

Copyright (c) 2012, Danny Garcia. All rights reserved.

Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions:

The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software.

THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.

Readme

Keywords

none

Package Sidebar

Install

npm i html2scss

Weekly Downloads

1

Version

0.8.7

License

none

Last publish

Collaborators

  • dannygarcia