- 投稿日:
WordPressの組み込みURL埋め込みがクソなので自作しようとしたら意味不明な挙動に出会ったので残しておく。
確認環境
- WordPress 6.2
- Classic Editor
起きた現象
端的に書くとshortcodeでAタグの中にブロック要素を含ませるような出力を記事本文中ですると初回だけAタグが外れます。
イメージ的にはこういう感じのやつ
<a href="https://example.com">
<figure>
<img src="https://example.com/foo.jpg" alt="" width="200">
<figcaption>foo</figcaption>
</figure>
</a>
例えば以下のような出力が起きます。ちょっとなんかかなりHTML崩壊してませんかね…?
理想 | 現実 |
---|---|
参考までにショートコードを二回以上書くと二回目以降はPタグなどのゴミが混ざるものの理想に近い出力になります。原因は不明。WordPressのバグかなんかじゃないかな…。
再現コード
このショートコードを記事本文に二回書くと二回目にはAタグが効くことが確認できます。
function emb_test($atts) {
$url = $atts["url"];
$img = $atts["img"];
$title = $atts["title"];
return <<<EOD
<a href="$url>
<figure>
<img src="$img" alt="" width="200">
<figcaption> $title </figcaption>
</figure>
</a>
EOD;
}
add_shortcode('emb', 'emb_test');
出力結果 |
---|
何故起きるのか?
wpautop のせいだとは思います。この機能自体は普段記事を書く上で便利ですし、タグやカテゴリの説明にadd_filter
してやるといい感じに改行が反映されたりして便利なのですが、shortcodeの中に入ってくるとかなり邪魔ですね…。
因みにAタグの中にインライン要素を入れてる限り、この現象は起きないのですが、その場合CSSでブロック要素にする必要があるのと、セマンティクスとかコーディング的な微妙さを感じたので、それはしないことにしました。
取り敢えずWordPressで良い感じにURLを埋め込むのは余り現実的ではなさそうなので諦めることにしました。正直WordPress 組み込みの埋込機能は使い勝手が悪く微妙です。有名SNSだけ埋め込めればいい人にはこれでいいでしょうけど…。
仕方がないので5年くらい前に使って体験が微妙だった Pz-LinkCard を使ってみたらかなり良くなっていたので、Pz-LinkCardを使うことで解決することにしました。ありがとうPz-LinkCard…ありがとう…。
コードの供養
書いたけど期待通り動かなかった本来やりたかったコードです。
function embed($atts) {
$url = count($atts) > 0
? $atts[0]
: "";
$dom = new DOMDocument();
$data = wp_remote_get($url);
if (is_wp_error($data)) {
return;
}
$html = $data['body'];
$doc = new DOMDocument();
@$doc->loadHTML($html);
$metas = $doc->getElementsByTagName('meta');
$title = '';
$description = '';
$image = '';
foreach ($metas as $meta) {
if ($meta->getAttribute('property') == 'og:title') {
$title = $meta->getAttribute('content');
}
if ($meta->getAttribute('property') == 'og:description') {
$description = $meta->getAttribute('content');
}
if ($meta->getAttribute('property') == 'og:image') {
$image = $meta->getAttribute('content');
}
}
if (!empty($title) && !empty($description)) {
return <<<EOD
<a href="$url">
<figure>
<img src="$image" alt="$title">
<figcaption>
$title
$description
</figcaption>
</figure>
</a>
EOD;
}
}
add_shortcode('embed', 'embed');
- 投稿日:
半年前にマンションの通気口そのものを交換して、いいヤツにしてみたのだが、それでも花粉がひどいのでフィルターを見たところ真っ黒になっていたので交換した話。因みに元の通気口は保管してるので原状回復に支障がないようにしている。
通気口
ユニックスのKRP 150BWFHを使っている。150cm経のやつ。よくあるプッシュ式で見た目もモダンでよい。
余談ですが元々あったのは PDG-AWFHで、部屋が負圧にならない限り吸気を止める構造だったので、換気をよくするために本製品に交換した。(恐らくキッチンの換気扇用で24h換気向けではない)。ついでに高性能フィルターが装備できたので装備している。
今回購入したフィルター
ユニックスのTF150A-KRPというフィルターを購入した。当面分買っておこうと3つ購入。公式サイトやマニュアルによると花粉を95%、PM2.5を50%捕獲できるとされており、かなり高性能なフィルターだ。
因みにフィルたんを併用することで更に花粉をカットできないか試して見たが、特に効果はなかった。恐らくユニックスのフィルターの性能が高く、その上にフィルたんを重ねたところで大きな効果はなかった。
ただフィルたん自体はよく考えられた製品で、色々な通気口に合わせられるように切れ込みが複数入っています。画像の中央の穴と下の裂け目も元々は埋まっていて、部品を外すことでこの形にできました。
特にスペックの記載がないにせよ結構な厚みがあるため、ちゃんとしたフィルターがないケースではそれなりに役に立ってくれそうな気もする。目が粗いのでどれほど活躍してくれるかは未知数だが…。
フィルター交換
左が今まで使ってたやつ、右が新品。半年でかなり真っ黒になっているのでフィルターとしてだいぶ仕事をしていてくれたことがわかる。マニュアルによると半年ごとの交換が推奨されているとのことでちょうどいいタイミングだった。
- 投稿日:
runas
では上手く出来ないっぽいのでPowerShellを呼んで実行する。管理者実行したいコマンドを分けたい時に活用できる。
確認環境
Env | Ver |
---|---|
Windows 11 Pro | 22621.1413 |
サンプルコード
powershell start-process <ここにコマンド> -verb runas
備考
PowerShellのリファレンスに沿って書くなら大文字小文字を書き分ける方がより正しいが、基本的に大文字と小文字を区別しないため、どっちでも動く。
powershell Start-Process <ここにコマンド> -Verb runAs
- 投稿日:
Microsoft製のNotionクローンと噂のLoopを軽く触ってみたのでその感想です。
あくまで軽く触ってみただけで間違っている部分もあるかと思うので、その際はご指摘いただけると助かります。
雑感
軽く触ってみたところ、現段階ではNotionには遠く及ばない感じがしました。
天下のMS製なので頑張ってほしいところですが、なんとなくNotionとは想定しているユーザー層が違うような気がしたので、ユースケースも違うのかもしれません。
テキストマークアップ機能について
通用しないMarkdownが多く、WYSIWYGに頼らないと記述は難しそうでした。一応キーボード操作で標準的なマークアップ自体はできるのですがMarkdownを手入力しているエンジニアにとってはやや煩雑だと感じます。更にCodefenceが存在しないためソースコードを書き込むのにも不便です。
文字色の設定はNotion同様に背景色か前景色が設定できるので悪くないと思います。
マークアップレンダリングの参考 |
---|
Database 機能について
Notionでは情報整理に重宝するDatabase機能ですが、Loopには存在しません。一番近いのはテーブルだと思うのですが、フィルタ機能がなく、Notionのマルチセレクトやリレーションのようなものも見当たらないので余り使えない気がします。その代わり投票機能があったりします。一応タスクリストや進行状況トラッカーというものもあるのですが、中身は単なるテーブルのテンプレート(Loopではコンポーネントと呼ばれている)のように見えました。
テーブルの参考 |
---|
ワークスペースについて
これに関してはLoopに分があり、1アカウントで複数のワークスペースを作ることが出来ます。Notionの場合は複数アカウント必要で切り替えも手間がかかるので、これは便利だなと思いました。
ワークスペース画面 |
---|
また、共同編集者も50人まで追加できるようなので、この機能が今後も無料で続くならNotionより使い勝手がいいかもしれません。Notionみたいにリアルタイムに同時更新できてカーソルとかまで出てくるのかまではわかりませんが…。
共同編集者の設定 |
---|
レイアウト機能とか
Notionはカラムを作ったり比較的自由に配置できますが、Loopの場合は特に何も出来ないようでがっかりしました。
あとページに画像を添付することが出来るのですが、Notionの場合画像を貼り付けた後に縮小しても画像をクリックすれば元画像が見れますが、Loopではクリックしても何も起きません。OneNoteと同じです。正直何を考えているのかわからない
UIとか
UIもなんか微妙な感じで、Notionと比べるとメニューのネストが深かったり、何が何処にあるのかイマイチわかりづらかったりして非直感的だと感じました。
ただメニューに切り取りとかコピーがある所から考えると、Notionよりライトなユーザーを想定しているのかもしれません。そういうユーザーには非合理的なUIのほうが受けが良い気もするので、なんとなく指針にうなずける気もします。
文字装飾 | 文字装飾続き | Notion の/ 相当 |
Notion の/ 相当続き |
---|---|---|---|
アプリについて
どうもLoopのAndroidアプリは現状個人では使えないようで、何かしらの組織で管理されたOffice 365に入ってないと使えないようでした。
個人的にはオフラインでも使えるNotionを期待していたのですが、現状を見るにNotionとは方向性が違うようなので仮に個人でアプリが使えるようになってもLoopを使うことが出てくるのかどうかは怪しい気がしました。
あとNotionのAndroidアプリって重かったり操作性が悪かったりして微妙なんですよね…。(この辺りはOneNoteが個人的に好みですが、OneNoteはNotionと比べた時に画像添付やページ管理が非力なのが微妙な感じ)
ざっくりとした大まかな機能比較
機能 | Notion | Loop | 備考 |
---|---|---|---|
Markdown | ✅ | ⚠️ | Loopでは見出しとリストくらいしか使えませんでした |
Database | ✅ | ❌ | Loopだとチケット管理や看板はできそうにないです 一応TODOリストレベルのものはあります |
マルチワークスペース | ❌ | ✅ | Loopは1アカウントで複数のワークスペースを持てますが、Notionは別アカウントが必要です。 |
レイアウト機能 | ✅ | ❌ | Loopは左右のレイアウト分割みたいなことは出来ないようです |
画像プレビュー | ✅ | ❌ | Loopでも添付画像の縮小はできますが、縮小した画像をクリックして元サイズを見ることは出来ません |