見出し画像

#03 ShopifyテーマキットでBootstrap5のオンラインショップを作る方法[初期設定]

このページではBootstrapをつかったShopifyのテーマの作り方を学ぶことができます。

Shopifyのテーマの中にBootstrapのCSSとJSを追加することで、BootstrapをつかったShopifyのテーマを作成することができます。

Bootstrapのダウンロード

Bootstrapのファイルは公式サイトからダウンロードできます。

コンパイルされた CSS と JSの見出しの「ダウンロード」ボタンから
ファイルをダウンロード可能(Bootstrap v5.0.0-beta1)

ダウンロードしたZipファイルを解凍し、「css」「js」フォルダから以下のファイルをShopifyのテーマの「assets」フォルダにコピーします。

Bootstrap「css」フォルダにある
・bootstrap.min.css
・bootstrap.min.css.map
Bootstrap「js」フォルダにある
・bootstrap.min.js
・bootstrap.min.js.map

ShopifyのテーマにBootstrapを反映させる

ダウンロードしたBootstrapのファイルをShopifyのテーマに読み込む方法です。「layout」フォルダにある「theme.liquid」を開きます。

「assets」フォルダにあるファイルcssとjsを読み込む方法は「theme.liquid」の中に元々あるコードを参考にします。

「theme.liquid」内のコード
{{ 'application.css.scss' | asset_url | stylesheet_tag }} 
{{ 'application.js' | asset_url | script_tag }}


  {{ 'application.css.scss' | asset_url | stylesheet_tag }}
Liquidについて
 {{  }}  括弧に囲まれている内容を出力する
②'application.css.scss' 
 |  縦棒(パイプ)=条件を追加するときに使う
④asset_url
⑤stylesheet_tag
実際に出力されるHTMLコード
<link href="//cdn.shopify.com/s/files/1/0602/3947/8954/t/2/assets/application.css.scss?v=00000" rel="stylesheet" type="text/css" media="all" />
① {{  }} この中に入れれるもの
Strings     文字列
Numbers    数字
Variables  変数
Objects    オブジェクト
②'application.css.scss' はHTMLではどこか? 太字部分
「assets」フォルダにある読み込むファイル名
<link href="//cdn.shopify.com/s/files/1/0602/3947/8954/t/2/assets/application.css.scss?v=00000" rel="stylesheet" type="text/css" media="all" />

・v=00000はCSSのバージョンを独自の数字で管理している
・Shopifyが勝手に出力している
④asset_url はHTMLではどこか? 太字部分
Shopifyのテーマの「assets」フォルダまでのパスを出力する
<link href="//cdn.shopify.com/s/files/1/0602/3947/8954/t/2/assets/application.css.scss?v=00000" rel="stylesheet" type="text/css" media="all" />
⑤stylesheet_tag はHTMLではどこか? 太字部分
HTMLのCSSの記述に必要なコードを出力する
<link href="
//cdn.shopify.com/s/files/1/0602/3947/8954/t/2/assets/application.css.scss?v=00000" rel="stylesheet" type="text/css" media="all" />

CSSに関する記述は以上です。

次はJSに関する記述ですが、CSSと同じような考え方で対応ができます。

{{ 'application.js' | asset_url | script_tag }}
実際に出力されるHTMLコード
<script src="//cdn.shopify.com/s/files/1/0602/3947/8954/t/2/assets/application.js?v=2933285453779101894" type="text/javascript"></script>

読み込みたいコードはBootstrapのコードなので、
以下のコードを上書きします。

「theme.liquid」内のコード 太字の箇所を変更する

{{ 'application.css.scss' | asset_url | stylesheet_tag }} 
{{ 'application.js' | asset_url | script_tag }}

{{ 'bootstrap.min.css' | asset_url | stylesheet_tag }} 
{{ 'bootstrap.min.js' | asset_url | script_tag }}

さらに「bootstrap.min.js」は</body>の直前に
コピー&ペーストで移動します。

</body>の直前に移動するコード
{{ 'bootstrap.min.js' | asset_url | script_tag }}

ターミナルを開き、自動更新のコマンドを入力

theme watch --allow-live

「theme.liquid」を上書き保存すると、

{{ 'bootstrap.min.css' | asset_url | stylesheet_tag }} 
{{ 'bootstrap.min.js' | asset_url | script_tag }}

で記述したHTMLのソースコードが追加されていましたが、実際にファイルがアップロードされていないので、リンク切れの状態になりました。

そこで「assets」フォルダにある「bootstrap.min.css」と「bootstrap.min.js」を開き、適当なところで改行を入れたあとに改行を削除し、上書き保存すると、ファイルがアップロードがされてました。

「theme watch --allow-live」の状態だと、ファイルを編集しないとアップロードされないので、外部から持ってきた新しくShopifyテーマに追加したファイルはこの手順でアップロードする必要があるみたいです。
フォルダに保存するだけで同期される(アップロードされる)方法があれば教えてほしいです。


今回は以下の2つのファイルも使用します。


「theme.liquid」のCSS部分の

{{ 'bootstrap.min.css' | asset_url | stylesheet_tag }} 

の下にコードを追加します。

{{ 'application.css.scss' | asset_url | stylesheet_tag }} 


「theme.liquid」のJS部分の

{{ 'bootstrap.min.js' | asset_url | script_tag }}

の下にコードを追加します。

{{ 'application.js' | asset_url | script_tag }}






いいなと思ったら応援しよう!