Jade with optional tags
中文文档
It's a W3C's spec: http://www.w3.org/html/wg/drafts/html/master/syntax.html#optional-tags
Install
npm install cutsin/jade
Usage
bash$ jade foo bar --omitTag [safe|radical|unsafe|dangerous]
var jade = require('jade')
var options = {
omitTag : 'radical'
}
var fn = jade.compileFile('./foo.jade', options)
var html = fn(locals)
Why?
-
Why we need optional tags
-
http://moonless.net/demo/optional-tags/
-
In browser, before HTML minify and after it, the result is different, because browser must be generated implied end tags.
-
In this w3's essay by Bert Bos, W3C/ERCIM, bert@w3.org, he used vast numbers of omitted tags.
It's really safe?
-
Sync with Jade, only a few changes.
-
If you using default option: true or 'safe', it's just provide 12 absolutely safe tags, most browsers(IE6+/chrome/safari/Firefox/Opera/...) works perfect.
-
Actually, it appeared in HTML 4.01, and we used many years on our corp's projects.
-
In test case, other levels will be fallback to "safe" when using "pretty: true", because it's really unsafe with space character and comment by w3's SPEC.
Other features
<style>
.a li {display:block}
.b1 li {display:inline-block}
.b2 li {display:inline}
</style>
<ul class="a">
<li>Hi~</li>
<li>ForbesLindesay</li>
</ul>
<ul class="b1">
<li>Hi~
<li>ForbesLindesay
</ul>
<ul class="b2">
<li>Hi~
<li>ForbesLindesay
</ul>
In browser, the rendering results are different, because of white-space processing model
In addition, according to omitted tag's implicit rules, we can do a lot of useful things.
Values for Jade, it can be reduce indentationslike this:
Must be: omitTag: 'radical'
at least
doctype html
html(lang="en")
//- `base` is a `head scope` only tag.
base(href="/n/contacts/")
p I'm main body.
ul
li
It can resolve the different rendering results on browser side(white-space processing model) when using pretty: true
License
MIT