Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/wandererxii/tstags


https://github.com/wandererxii/tstags

Last synced: 14 days ago
JSON representation

Awesome Lists containing this project

README

        

# tsTags: typescript HTML generator

[![npm](https://img.shields.io/npm/v/@liskadan/tstags)](https://www.npmjs.com/package/@liskadan/tstags)

Simply and quickly generate HTML. No need to write HTML directly.

## What it does?

Turns this:

```typescript
section([
h1(article.title),
h2(article.subtitle),
div({ class: 'my-class' }, p(article.text)),
]);
```

Into this:

```html

Title


Subtitle



Lorem ipsum dolor sit amet consectetur adipisicing elit.


```

### Custom tags

You can also use custom tags:

```typescript
tag('outer-tag', tag('inner-tag'));
```

And generate:

```html

```

### CSS-like class and id specifiers

With `tag` you can also specify class and id in the selector.

```typescript
tag('div.wrap', tag('div#id123'));
```

```HTML


```

`tag` might also be better, that you don't need to import a separate function for each tag type.

### Syntax

#### Empty elements:

```typescript
title();
// or
tag('title');
```

Both become the same:

```HTML

```

#### Attributes:

```typescript
a({ href: 'url' });
// or
tag('a', { href: 'url' });
```

```HTML

```

#### Inner data:

String:

```typescript
div('Content');
// or
tag('div', 'Content');
```

```HTML

Content

```

Element:

```typescript
div(button());
// or
tag('div', tag('button'));
```

```HTML


```

Or multiple inner elements:

```typescript
ul([
li('Apples'),
li('Bees'),
li('Cider'),
li('Deer'),
li('Egg'),
li('Fruit'),
li('Gorilla'),
]);
// or
tag('ul', [
tag('li', 'Apples'),
tag('li', 'Bees'),
tag('li', 'Cider'),
tag('li', 'Deer'),
tag('li', 'Egg'),
tag('li', 'Fruit'),
tag('li', 'Gorilla'),
]);
```

```HTML


  • Apples

  • Bees

  • Cider

  • Deer

  • Egg

  • Fruit

  • Gorilla


```

Of course you can combine the syntax in any reasonable way. The advantage of tag is that you need to import only one function, which may or may not matter, depending on your use-case.

Generated HTML is not formatted.

If you want to write the result to a file, simply use something like:

```javascript
fs = require('fs');

fs.writeFileSync('index.html', myGeneratedHtml);
```

### Tag description

MDN description in tooltip.

![Description](./desc.png)