Skip to content

Vue directive that eliminates whitespace between elements.

License

Notifications You must be signed in to change notification settings

ianpurvis/vue-tight

Repository files navigation

continuous codecov

Vue-Tight

As a developer,
I want to prune whitespace between inline elements,
so that I can write tight layouts.

Background

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>

Exam ple

In order to eliminate whitespace between inline elements, you must eliminate that whitespace at the source:

<h3>
  <span>Exam</span><span>ple</span>
</h3>

Example

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.

Usage

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.

Links

License

This package is available as open source under the terms of the MIT License.

https://purvisresearch.com