<?xml version="1.0" encoding="UTF-8"?><rss version="2.0"
	xmlns:content="http://purl.org/rss/1.0/modules/content/"
	xmlns:wfw="http://wellformedweb.org/CommentAPI/"
	xmlns:dc="http://purl.org/dc/elements/1.1/"
	xmlns:atom="http://www.w3.org/2005/Atom"
	xmlns:sy="http://purl.org/rss/1.0/modules/syndication/"
	xmlns:slash="http://purl.org/rss/1.0/modules/slash/"
	>

<channel>
	<title>npm  |  takeHo（たけほ）のへなちょこ台帳</title>
	<atom:link href="https://blog.takeho.com/tag/npm/feed/" rel="self" type="application/rss+xml" />
	<link>https://blog.takeho.com</link>
	<description>いわゆる自由帳ってところです。</description>
	<lastBuildDate>Wed, 22 Apr 2026 02:58:54 +0000</lastBuildDate>
	<language>ja</language>
	<sy:updatePeriod>
	hourly	</sy:updatePeriod>
	<sy:updateFrequency>
	1	</sy:updateFrequency>
	<generator>https://wordpress.org/?v=6.6</generator>

<image>
	<url>https://blog.takeho.com/wp-content/uploads/2024/08/icon-150x150.png</url>
	<title>npm  |  takeHo（たけほ）のへなちょこ台帳</title>
	<link>https://blog.takeho.com</link>
	<width>32</width>
	<height>32</height>
</image> 
	<item>
		<title>Rocky Linuxで始めるTailwind CSS入門：Bootstrapとの違いから導入・運用まで</title>
		<link>https://blog.takeho.com/l2eitulk0boefkvg1rx9nxdt2wptujpb/</link>
					<comments>https://blog.takeho.com/l2eitulk0boefkvg1rx9nxdt2wptujpb/#respond</comments>
		
		<dc:creator><![CDATA[たけほ]]></dc:creator>
		<pubDate>Wed, 22 Apr 2026 11:58:00 +0000</pubDate>
				<category><![CDATA[ウェブ・開発]]></category>
		<category><![CDATA[CI4]]></category>
		<category><![CDATA[Linux]]></category>
		<category><![CDATA[npm]]></category>
		<category><![CDATA[tailwindcss]]></category>
		<guid isPermaLink="false">https://blog.takeho.com/?p=1863</guid>

					<description><![CDATA[Tailwindは非常に柔軟なCSSフレームワークですが、Bootstrapとは設計思想が大きく異なるため、従来のPHP中心の開発に慣れている場合は戸惑うポイントも少なくありません。 特に以下のような疑問がよく出てきます [&#8230;]]]></description>
										<content:encoded><![CDATA[
<p>Tailwindは非常に柔軟なCSSフレームワークですが、Bootstrapとは設計思想が大きく異なるため、従来のPHP中心の開発に慣れている場合は戸惑うポイントも少なくありません。</p>



<p>特に以下のような疑問がよく出てきます。</p>



<ul class="wp-block-list">
<li>Composerで導入できないのはなぜか</li>



<li>設定ファイルはどこに置くべきか</li>



<li>監視コマンドはなぜ止まらないのか</li>
</ul>



<p>こうした疑問を、PHPフレームワーク CodeIgniter4のディレクトリ構成をベースに整理しながら、実際に動く形で説明していきます。</p>




  <div id="toc" class="toc tnt-number toc-center tnt-number border-element"><input type="checkbox" class="toc-checkbox" id="toc-checkbox-2"><label class="toc-title" for="toc-checkbox-2">目次</label>
    <div class="toc-content">
    <ol class="toc-list open"><li><a href="#toc1" tabindex="0">前提環境</a></li><li><a href="#toc2" tabindex="0">設定ファイルの作成と配置場所</a></li><li><a href="#toc3" tabindex="0">content設定（CI4特有ポイント）</a></li><li><a href="#toc4" tabindex="0">CSS読み込み（CI4）</a></li><li><a href="#toc5" tabindex="0">監視コマンドの意味（CI4でも共通）</a></li><li><a href="#toc6" tabindex="0">ターミナルが使えなくなる理由</a></li><li><a href="#toc7" tabindex="0">ターミナルを閉じても動かす方法</a></li><li><a href="#toc8" tabindex="0">本番環境での注意（CI4）</a></li><li><a href="#toc9" tabindex="0">まとめ</a></li></ol>
    </div>
  </div>

<h2 class="wp-block-heading"><span id="toc1">前提環境</span></h2>



<p>本記事は以下の構成を前提としています。</p>



<figure class="wp-block-table"><table class="has-fixed-layout"><thead><tr><th>項目</th><th>内容</th></tr></thead><tbody><tr><td>OS</td><td>Rocky Linux</td></tr><tr><td>フレームワーク</td><td>CodeIgniter4</td></tr><tr><td>Web公開ディレクトリ</td><td>public/</td></tr><tr><td>View配置</td><td>app/Views/</td></tr><tr><td>パッケージ管理（PHP）</td><td>Composer</td></tr><tr><td>パッケージ管理（CSS/JS）</td><td>npm</td></tr></tbody></table></figure>



<h2 class="wp-block-heading"><span id="toc2">設定ファイルの作成と配置場所</span></h2>



<p>CodeIgniter4環境では、Tailwind関連ファイルの配置は以下になります。</p>



<pre class="wp-block-preformatted">/プロジェクトルート<br>├── app/<br>│   └── Views/<br>├── public/<br>│   └── css/<br>├── writable/<br>├── vendor/<br>├── package.json<br>├── tailwind.config.js<br>├── input.css</pre>



<p>ここで重要なのは以下です。</p>



<figure class="wp-block-table"><table class="has-fixed-layout"><thead><tr><th>ファイル</th><th>配置理由</th></tr></thead><tbody><tr><td>tailwind.config.js</td><td>npm実行基準（プロジェクトルート）</td></tr><tr><td>input.css</td><td>ビルド元CSS</td></tr><tr><td>public/css/app.css</td><td>ブラウザ配信用</td></tr></tbody></table></figure>



<p>特に <code>tailwind.config.js</code> は<br><strong>package.jsonと同じ階層に置く必要があります。</strong></p>



<h2 class="wp-block-heading"><span id="toc3">content設定（CI4特有ポイント）</span></h2>



<pre class="wp-block-preformatted">export default {<br>  content: [<br>    "./app/Views/**/*.php",<br>  ],<br>}</pre>



<p>これはCodeIgniter4特有です。</p>



<ul class="wp-block-list">
<li>Viewファイルが <code>app/Views</code> にあるためTailwindがクラスを検出するために必須</li>
</ul>



<h2 class="wp-block-heading"><span id="toc4">CSS読み込み（CI4）</span></h2>



<pre class="wp-block-preformatted">&lt;link href="/css/app.css" rel="stylesheet"&gt;</pre>



<p>CI4では <code>public/</code> がドキュメントルートのため<br><code>/css/app.css</code> で参照できます</p>



<h2 class="wp-block-heading"><span id="toc5">監視コマンドの意味（CI4でも共通）</span></h2>



<pre class="wp-block-preformatted">npx tailwindcss -i input.css -o public/css/app.css --watch</pre>



<p>このコマンドは</p>



<ul class="wp-block-list">
<li>View（app/Views）を監視</li>



<li>クラス変更を検知</li>



<li>CSSを再生成</li>
</ul>



<p>という動作になります。</p>



<h2 class="wp-block-heading"><span id="toc6">ターミナルが使えなくなる理由</span></h2>



<p>これはCI4固有ではなく、Tailwindの仕様です。</p>



<figure class="wp-block-table"><table class="has-fixed-layout"><thead><tr><th>状態</th><th>説明</th></tr></thead><tbody><tr><td>watch実行</td><td>常駐プロセス</td></tr><tr><td>ターミナル占有</td><td>正常動作</td></tr><tr><td>Ctrl+C</td><td>終了</td></tr></tbody></table></figure>



<h2 class="wp-block-heading"><span id="toc7">ターミナルを閉じても動かす方法</span></h2>



<p>サーバ上でCI4を動かす場合は以下が現実的です。</p>



<pre class="wp-block-preformatted">nohup npx tailwindcss -i input.css -o public/css/app.css --watch &gt; tailwind.log 2&gt;&amp;1 &amp;</pre>



<p>または</p>



<pre class="wp-block-preformatted">tmux</pre>



<p>→ セッションを分離して運用</p>



<h2 class="wp-block-heading"><span id="toc8">本番環境での注意（CI4）</span></h2>



<p>本番ではwatchは使いません。</p>



<pre class="wp-block-preformatted">npx tailwindcss -i input.css -o public/css/app.css --minify</pre>



<p>CI4は静的ファイルをそのまま配信するため事前ビルドのみでOK</p>



<h2 class="wp-block-heading"><span id="toc9">まとめ</span></h2>



<p>今回の内容は「単なるTailwind導入」ではなく、<strong>CodeIgniter4環境での正しい配置と運用</strong> がポイントです。</p>



<p>特に重要なのは以下です。</p>



<ul class="wp-block-list">
<li>Composerではなくnpmを使う</li>



<li>設定ファイルはプロジェクトルート</li>



<li>Viewパスをcontentに指定</li>



<li>watchは開発専用</li>
</ul>



<p>Tailwindは最初こそBootstrapより手間に感じますが、<br>一度慣れると「レイアウトの自由度」が段違いです。</p>



<div class="wp-block-cocoon-blocks-blogcard blogcard-type bct-none">

<a rel="noopener" href="https://tailwindcss.com/" title="Tailwind CSS - Rapidly build modern websites without ever leaving your HTML." class="blogcard-wrap external-blogcard-wrap a-wrap cf" target="_blank"><div class="blogcard external-blogcard eb-left cf"><div class="blogcard-label external-blogcard-label"><span class="fa"></span></div><figure class="blogcard-thumbnail external-blogcard-thumbnail"><img decoding="async" src="https://tailwindcss.com/opengraph-image.jpg?opengraph-image.c1dec83c.jpg" alt="" class="blogcard-thumb-image external-blogcard-thumb-image" width="160" height="90" /></figure><div class="blogcard-content external-blogcard-content"><div class="blogcard-title external-blogcard-title">Tailwind CSS - Rapidly build modern websites without ever leaving your HTML.</div><div class="blogcard-snippet external-blogcard-snippet">Tailwind CSS is a utility-first CSS framework for rapidly building modern websites without ever leaving your HTML.</div></div><div class="blogcard-footer external-blogcard-footer cf"><div class="blogcard-site external-blogcard-site"><div class="blogcard-favicon external-blogcard-favicon"><img decoding="async" src="https://www.google.com/s2/favicons?domain=https://tailwindcss.com/" alt="" class="blogcard-favicon-image external-blogcard-favicon-image" width="16" height="16" /></div><div class="blogcard-domain external-blogcard-domain">tailwindcss.com</div></div></div></div></a>
</div>
]]></content:encoded>
					
					<wfw:commentRss>https://blog.takeho.com/l2eitulk0boefkvg1rx9nxdt2wptujpb/feed/</wfw:commentRss>
			<slash:comments>0</slash:comments>
		
		
			</item>
	</channel>
</rss>
