As a developer,
I want to prune whitespace between inline elements,
so that I can write tight layouts.
We often use whitespace to make HTML more readable. However, when creating layouts with inline elements, that whitespace can become problematic.
For example, the spans in the following code are separated by collapsed whitespace:
<h3>
<span>Exam</span>
<span>ple</span>
</h3>
In order to eliminate whitespace between inline elements, you must eliminate that whitespace at the source:
<h3>
<span>Exam</span><span>ple</span>
</h3>
However, this can create long, unmanageable lines of code. One workaround for eliminating whitespace while preserving readability has been to insert line-breaking comments between inline elements:
<h3><!--
--><span>Exam</span><!--
--><span>ple</span>
</h3>
Or, you might style a parent element with font-size: 0
while styling its children with the intended font size:
<style type="text/css">
.tight { font-size: 0 }
.tight > * { font-size: 1.25rem }
</style>
<h3 class="tight">
<span>Exam</span>
<span>ple</span>
</h3>
But, if these workarounds feel gross to you, you are in the right place. This is a Vue directive to prune whitespace at render-time.
First, install with npm
:
$ npm i vue-tight
Or yarn
:
$ yarn add vue-tight
Next, register the directive globally:
import Vue from 'vue'
import Tight from 'vue-tight'
Vue.directive('tight', Tight)
Or, register it locally for a particular component or mixin:
import Tight from 'vue-tight'
export default {
name: 'MyComponent',
directives: { Tight }
}
Finally, add the v-tight
directive to your template elements:
<div v-tight>
<span>Exam</span>
<span>ple</span>
</div>
And voilà! Whitespace between the children of the tightened element will not be rendered.
- CSS2 Whitespace Processing Model
- Fighting the Space Between Inline Block Elements
- Vue.js Custom Directives
This package is available as open source under the terms of the MIT License.