5
2

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

More than 5 years have passed since last update.

PostHTMLプラグインの作り方

Last updated at Posted at 2017-12-28

PostHTMLについて

PostCSSのHTMLバージョンを目指すもPostCSSでいうautoprefixerのようなものがないためにあまり注目されていません。
他のプラグインは全く使ってないですが、自分用にプラグイン作って使うにはちょうどいいような気がします。
結構簡単に作れるので簡潔に説明してみます。

作り方

ガイドがあるので一度読んでおくといいです。

作りがシンプルなので例を見たほうがはやいと思います。
全てのspanタグをpタグに変えるプラグインの例です。

index.js
export default tree => {
  tree.match({ tag: 'span' }, node => {
    node.tag = 'p';
    return node;
  });
}

treeはASTにPostHTMLのAPIをつけたものです。
ASTの構成はposthtml-parserに書いています。

APIがtree.match(expression, cb)tree.walk(cb)の2つしかなく、walkのほうは全ノード見ることになるのであまり使わないと思います。
なので基本的にtree.match()で処理していくことになります。  
posthtml-match-helperを使えばセレクタ指定っぽくもできます。

ちなみにAPIを使わずに直接操作しても問題ありません。
親要素や兄弟要素にアクセスしたくなったときなどは直接触るしかありません・・・。

上記を覚えておけばとりあえずはつまることもなく作れると思います。
ベースが欲しい場合はposthtml-plugin-boilerplateを使いましょう。

その他

PostHTMLは一応二種類の使い方があります。

  • async posthtml([plugin1, plugin2]).process(html).then(res => res.html)
  • sync posthtml().use(plugin1, plugin2).process(html, {sync: true}).html

こういうのを作っています。
srcsetがとても嫌いなのでどうにかして楽に書きたいです。

5
2
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
5
2

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?