目次
キーテイクアウト
うわー、それは短かった。今必要なのは、StyleSheetsフォルダーでSASS(実際にgulp-sass)を実行する
パイプ
プロジェクトにgulpとsassをインストールするには、コンピューターにnode.jsとnpmをインストールする必要があります。これらを手に入れると、ターミナルでコマンドNPMインストール-Global Gulp-Cliを実行して、Gulpをグローバルにインストールできます。その後、プロジェクトディレクトリに移動し、NPM initを実行してpackage.jsonファイルを作成します。次に、NPMインストールを実行して、プロジェクトにGulpとGulp-Sassをインストールします - save-dev gulp gulp-sass。
今では、SASSファイルに構文エラーがあるときはいつでも、gulp-sassはエラーを記録し、タスク。
このタスクは、スタイルディレクトリのすべての.cssファイルを取得し、それらを使用して削除しますgulp-clean-css、および結果として得られた模倣CSSファイルをdistディレクトリに出力します。
ホームページ ウェブフロントエンド jsチュートリアル SASS用のシンプルなGulp' Yワークフロー

SASS用のシンプルなGulp' Yワークフロー

Feb 19, 2025 pm 12:40 PM

SASS用のシンプルなGulp' Yワークフロー

キーテイクアウト

  • ガルプワークフローは、大規模なRailsプロジェクトでのSASS編集時間を改善し、資産パイプラインから離れ、Libsassの速度を受け入れることができます。
  • gulpワークフローには、libsassとのSASSコンピレーション、デバッグを簡単にするためのSourcemapsの生成、CSSの自動化合物のプレフィックス、SassdocでのSASSドキュメントの生成が含まれます。
  • ワークフローは、スタイルシートの変更を監視してそれらを再コンパイルするウォッチタスクを追加し、ファイルを保存するたびにSASSタスクを手動で実行する必要性を排除することにより、さらに最適化できます。
  • 「製品」タスクは、圧縮モードでSASSをコンパイルし、CSSをオートプレフィキサーで接頭辞し、SASSDOCドキュメントを再生し、SassDOCのドキュメントを回避するために、生産に展開するために作成できます。
  • 私は最近、非常に大きなRailsプロジェクトのSASS側の最適化を担当しており、最も重要なことの1つは、コンピレーション時間を改善することでした。 SASSアーキテクチャが配置されており、Ruby Sass(この場合はRails Asset Pipelineを介して)が膨大な数のファイルを扱うと遅くなる傾向があるため、スタイルシートをコンパイルするのに最大40秒かかる可能性があります。迅速な開発プロセスについて話します。 :)
  • 私の考えは、資産パイプラインから離れて、libsassの速度を受け入れることでした。物事を簡単にするために、私は簡単なガルプワークフローを使用することにしました。 Gulpを使用するのは初めてでしたが、それは非常に楽しい経験だったと言わざるを得ません(私が懸念している限り、うなり声の場合はそうではありませんでした)。 この短い記事では、SASSを使用するためにGulp’yワークフローをセットアップする方法について簡単なツアーをしましょう。これが私たちが含めるものです:

当然のことながら、libsass

とのsass編集

デバッグを容易にするためのSourceMapsの生成

autoprefixerを使用してCSSをプレフィックスします

Sassdoc
    を使用してSASSドキュメントを生成します
  • sass
  • コンパイル Atozを見る:Sass 手紙でサスの手紙を学びます
  • このコースをご覧ください このコースをご覧ください
  • 最初に行うことは、依存関係をインストールし、gulpfile.jsを作成することです。ガルプ(たわごとはありません、シャーロック)だけでなく、スタイルシートをコンパイルするためにガルプサスも必要です:
  • この行は、NPMに、開発依存関係としてGulpとGulp-Sassパッケージの両方をインストールするように指示します。 Package.jsonのdevdependenciesオブジェクトでそれらを見つけることができます。およびgulpfile.js:

うわー、それは短かった。今必要なのは、StyleSheetsフォルダーでSASS(実際にgulp-sass)を実行する

タスクSASS用のシンプルなGulp' Yワークフローです。
$ <span>npm install gulp gulp-sass --save-dev</span>
ログイン後にコピー
ログイン後にコピー

それだけです!非常に最小限のGulpタスクのおかげで、Libsassを使用してStyleSheetsをコンパイルできるようになりました。それはどうですか? Gulp-Sassにオプションを渡すには、拡張モードでStyleSheetsをコンパイルし、コンソールにエラーを印刷することができます。

<span>var gulp = require('gulp');
</span><span>var sass = require('gulp-sass');</span>
ログイン後にコピー
ログイン後にコピー
sourcemapsの追加

これまでのところ

とても良いです。さて、SourceMapsを生成するのはどうですか? Sourcemapsが何であるかわからない場合は、基本的に、ライブコードのデバッグを容易にするために、圧縮生産ソースを開発ソースとマッピングする方法です。それらはまったくCSSに制限されていません、SourceMapsはJavaScriptでも使用できます。

SetePointでSourceMapsについての素敵な記事があります。 Sourcemapsの理解が少し不足していると感じたら、先に読んでください。

さて、SourceMapsの生成をタスクに追加するには、Gulp-Sourcemaps:

をインストールする必要があります。

そして、タスクを最適化しましょう:

<span>var input = './stylesheets/**/*.scss';
</span><span>var output = './public/css';
</span>
gulp<span>.task('sass', function () {
</span>  <span>return gulp
</span>    <span>// Find all `.scss` files from the `stylesheets/` folder
</span>    <span>.src(input)
</span>    <span>// Run Sass on those files
</span>    <span>.pipe(sass())
</span>    <span>// Write the resulting CSS in the output folder
</span>    <span>.pipe(gulp.dest(output));
</span><span>});</span>
ログイン後にコピー
ログイン後にコピー

デフォルトでは、Gulp-Sourcemapsは、コンパイルされたCSSファイルにSourcemapsをインラインで書き込みます。プロジェクトのセットアップに応じて、それらを別々のファイルに記述することをお勧めします。その場合、sourcemaps.write()functionのgulp.dest()宛先に関連するパスを指定できます。

<span>var sassOptions = {
</span>  <span>errLogToConsole: true,
</span>  <span>outputStyle: 'expanded'
</span><span>};
</span>
gulp<span>.task('sass', function () {
</span>  <span>return gulp
</span>    <span>.src(input)
</span>    <span>.pipe(sass(sassOptions).on('error', sass.logError))
</span>    <span>.pipe(gulp.dest(output));
</span><span>});</span>
ログイン後にコピー
ログイン後にコピー
パーティーにオートプレフィキサーを持ち込む

Autoprefixerを使用することが手でベンダーを書くよりも良い理由(または基本的に同じもの)を使用するよりも詳細に説明することはありませんが、ほぼAutoprefixerは、実際に既にコンパイルされた更新を更新することを意味します。最新のデータベースと特定の構成に基づいて、関連するプレフィックスを追加するスタイルシート。言い換えれば、あなたはあなたがサポートするブラウザをAutoprefixerに伝え、それはスタイルシートに関連するプレフィックスのみを追加します。努力はゼロ、完璧なサポート(このキャッチフレーズの特許をとることを思い出させてください)。
$ <span>npm install gulp-sourcemaps --save-dev</span>
ログイン後にコピー
ログイン後にコピー
Gulp’yワークフローにAutoprefixerを含めるには、SASSがそのことを行った後に

パイプ

にのみ必要です。次に、Autoprefixerはスタイルシートを更新してプレフィックスを追加します

最初に、インストールしましょう(今までに要点を取得します):

次に、タスクに追加します:

今、

です。
<span>var gulp = require('gulp');
</span><span>var sass = require('gulp-sass');
</span><span>var sourcemaps = require('gulp-sourcemaps');
</span>
<span>// ... variables
</span>
gulp<span>.task('sass', function () {
</span>  <span>return gulp
</span>    <span>.src(input)
</span>    <span>.pipe(sourcemaps.init())
</span>    <span>.pipe(sass(sassOptions).on('error', sass.logError))
</span>    <span>.pipe(sourcemaps.write())
</span>    <span>.pipe(gulp.dest(output));
</span><span>});</span>
ログイン後にコピー
ログイン後にコピー
1%以上の市場シェアを持つ

ブラウザ、

すべてのブラウザの最後の2つのバージョン、
gulp<span>.task('sass', function () {
</span>  <span>return gulp
</span>    <span>.src(input)
</span>    <span>.pipe(sourcemaps.init())
</span>    <span>.pipe(sass(sassOptions).on('error', sass.logError))
</span>    <span>.pipe(sourcemaps.write('./stylesheets/maps'))
</span>    <span>.pipe(gulp.dest(output));
</span><span>});</span>
ログイン後にコピー
ログイン後にコピー

firefox esr、

    オペラ12.1
  • soのような独自の構成を使用できます
  • ドキュメントをリリース!
  • 最後になりましたが、ワークフロー、SASSDOCのSASSドキュメント生成に追加するツール。 Sassdocは、JSDOCがJavaScript:ドキュメントツールをSASSすることです。変数、ミキシン、機能、プレースホルダーを文書化するコメントブロックを探しているスタイルシートを解析します。 Sassdocのクールなことは、APIがGulp互換性があるため、Gulpに直接配管できることです。したがって、実際にはGulp-Sassdocプラグインはありません
    $ <span>npm install gulp gulp-sass --save-dev</span>
    ログイン後にコピー
    ログイン後にコピー
    <span>var gulp = require('gulp');
    </span><span>var sass = require('gulp-sass');</span>
    ログイン後にコピー
    ログイン後にコピー
    プロジェクトのサイズと文書化されたアイテムの数に応じて、Sassdocは実行するのに最大数秒かかる可能性があることに注意してください(私が気づいた限りではめったに3を上回ることはありません)。これのために別々のタスク。

    <span>var input = './stylesheets/**/*.scss';
    </span><span>var output = './public/css';
    </span>
    gulp<span>.task('sass', function () {
    </span>  <span>return gulp
    </span>    <span>// Find all `.scss` files from the `stylesheets/` folder
    </span>    <span>.src(input)
    </span>    <span>// Run Sass on those files
    </span>    <span>.pipe(sass())
    </span>    <span>// Write the resulting CSS in the output folder
    </span>    <span>.pipe(gulp.dest(output));
    </span><span>});</span>
    ログイン後にコピー
    ログイン後にコピー
    繰り返しますが、デフォルトの構成を使用しますが、必要に応じて独自の構成を使用できます。

    私はあなたを見ています
    <span>var sassOptions = {
    </span>  <span>errLogToConsole: true,
    </span>  <span>outputStyle: 'expanded'
    </span><span>};
    </span>
    gulp<span>.task('sass', function () {
    </span>  <span>return gulp
    </span>    <span>.src(input)
    </span>    <span>.pipe(sass(sassOptions).on('error', sass.logError))
    </span>    <span>.pipe(gulp.dest(output));
    </span><span>});</span>
    ログイン後にコピー
    ログイン後にコピー

    去る前にできることはまだあります:時計タスクを作成します。このタスクのポイントは、スタイルシートの変更を監視して再び再コンパイルすることです。プロジェクトのSASS側で作業する場合は非常に便利です。ファイルを保存するたびにSASSタスクを手作業で実行する必要はありません。

    最後のタッチを追加
    $ <span>npm install gulp-sourcemaps --save-dev</span>
    ログイン後にコピー
    ログイン後にコピー

    最後の、しかし重要なことを考えるべきこと:デフォルトのタスクでSASSを実行します。

    タスク(..)関数の2番目の引数として渡された配列は、依存関係タスクのリストです。基本的に、3番目の引数として指定されたタスクを実行する前に、これらのタスクを実行するようにGulpに指示します(もしあれば)。 また、生産に展開する直前に実行できる製品タスクを作成する可能性があります(おそらくGitフック付き)。このタスクは次のとおりです

    圧縮モードでSASSをコンパイルします
    <span>var gulp = require('gulp');
    </span><span>var sass = require('gulp-sass');
    </span><span>var sourcemaps = require('gulp-sourcemaps');
    </span>
    <span>// ... variables
    </span>
    gulp<span>.task('sass', function () {
    </span>  <span>return gulp
    </span>    <span>.src(input)
    </span>    <span>.pipe(sourcemaps.init())
    </span>    <span>.pipe(sass(sassOptions).on('error', sass.logError))
    </span>    <span>.pipe(sourcemaps.write())
    </span>    <span>.pipe(gulp.dest(output));
    </span><span>});</span>
    ログイン後にコピー
    ログイン後にコピー

    autoprefixerを使用したcssプレフィックス

    Sassdocドキュメントを再生します

  • 最終的な考え
  • それは皆さんです!数分と数行のJavaScriptで、強力な小さなガルプワークフローを作成することができました。ここで完全なファイルを見つけることができます。何に追加しますか?
  • ガルプとSASSワークフローに関するよくある質問(FAQ)
プロジェクトにgulpとsassをインストールするにはどうすればよいですか?
gulp<span>.task('sass', function () {
</span>  <span>return gulp
</span>    <span>.src(input)
</span>    <span>.pipe(sourcemaps.init())
</span>    <span>.pipe(sass(sassOptions).on('error', sass.logError))
</span>    <span>.pipe(sourcemaps.write('./stylesheets/maps'))
</span>    <span>.pipe(gulp.dest(output));
</span><span>});</span>
ログイン後にコピー
ログイン後にコピー

プロジェクトにgulpとsassをインストールするには、コンピューターにnode.jsとnpmをインストールする必要があります。これらを手に入れると、ターミナルでコマンドNPMインストール-Global Gulp-Cliを実行して、Gulpをグローバルにインストールできます。その後、プロジェクトディレクトリに移動し、NPM initを実行してpackage.jsonファイルを作成します。次に、NPMインストールを実行して、プロジェクトにGulpとGulp-Sassをインストールします - save-dev gulp gulp-sass。

​​Gulpを使用してSASSファイルをコンパイルするには、Gulpタスクを作成する必要があります。 gulpfile.jsでは、SASSファイルをCSSにコンパイルする「SASS」という名前のタスクを作成できます。これを行う方法の簡単な例は次のとおりです。 ( 'sass'、function(){

return gulp.src( './ sass/**/*。scss ')
.pipe(sass()。on(' error '、sass.logerror))
.pipe(gulp.dest(' ./ css '));
}))) ; });

sassディレクトリに.scssファイルを保存するたびに、「SASS」タスクは自動的にSASSファイルをCSSにコンパイルします。 SASSファイルのエラーを処理するにはどうすればよいですか?

SASSファイルをコンパイルすると、構文エラーが発生する可能性があります。これらのエラーは、Gulp-Sassが提供するONメソッドを使用して処理できます。 「SASS」タスクを変更してエラーを記録する方法は次のとおりです。 scss ')
.pipe(sass()。on(' error '、sass.logerror))
.pipe(gulp.dest( './ css'));
});

今では、SASSファイルに構文エラーがあるときはいつでも、gulp-sassはエラーを記録し、タスク。

gulpを使用してCSSファイルをマイニングするにはどうすればよいですか?
​​
Gulp-Clean-CSSと呼ばれるプラグイン。まず、NPMインストールを実行してプロジェクトにインストールします - ave-dev gulp-clean-css。次に、CSSファイルをマイニングするタスクを作成できます。 ()=> {
return gulp.src( 'styles/*。css')
.pipe(cleancss({compatibility: 'ie8'})))
.pipe(gulp.dest( 'dist'));
});

このタスクは、スタイルディレクトリのすべての.cssファイルを取得し、それらを使用して削除しますgulp-clean-css、および結果として得られた模倣CSSファイルをdistディレクトリに出力します。

以上がSASS用のシンプルなGulp&#x27; Yワークフローの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

Video Face Swap

Video Face Swap

完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

フロントエンドのサーマルペーパーレシートのために文字化けしたコード印刷に遭遇した場合はどうすればよいですか? フロントエンドのサーマルペーパーレシートのために文字化けしたコード印刷に遭遇した場合はどうすればよいですか? Apr 04, 2025 pm 02:42 PM

フロントエンドのサーマルペーパーチケット印刷のためのよくある質問とソリューションフロントエンド開発におけるチケット印刷は、一般的な要件です。しかし、多くの開発者が実装しています...

javascriptの分解:それが何をするのか、なぜそれが重要なのか javascriptの分解:それが何をするのか、なぜそれが重要なのか Apr 09, 2025 am 12:07 AM

JavaScriptは現代のWeb開発の基礎であり、その主な機能には、イベント駆動型のプログラミング、動的コンテンツ生成、非同期プログラミングが含まれます。 1)イベント駆動型プログラミングにより、Webページはユーザー操作に応じて動的に変更できます。 2)動的コンテンツ生成により、条件に応じてページコンテンツを調整できます。 3)非同期プログラミングにより、ユーザーインターフェイスがブロックされないようにします。 JavaScriptは、Webインタラクション、シングルページアプリケーション、サーバー側の開発で広く使用されており、ユーザーエクスペリエンスとクロスプラットフォーム開発の柔軟性を大幅に改善しています。

誰がより多くのPythonまたはJavaScriptを支払われますか? 誰がより多くのPythonまたはJavaScriptを支払われますか? Apr 04, 2025 am 12:09 AM

スキルや業界のニーズに応じて、PythonおよびJavaScript開発者には絶対的な給与はありません。 1. Pythonは、データサイエンスと機械学習でさらに支払われる場合があります。 2。JavaScriptは、フロントエンドとフルスタックの開発に大きな需要があり、その給与もかなりです。 3。影響要因には、経験、地理的位置、会社の規模、特定のスキルが含まれます。

JavaScriptは学ぶのが難しいですか? JavaScriptは学ぶのが難しいですか? Apr 03, 2025 am 12:20 AM

JavaScriptを学ぶことは難しくありませんが、挑戦的です。 1)変数、データ型、関数などの基本概念を理解します。2)非同期プログラミングをマスターし、イベントループを通じて実装します。 3)DOM操作を使用し、非同期リクエストを処理することを約束します。 4)一般的な間違いを避け、デバッグテクニックを使用します。 5)パフォーマンスを最適化し、ベストプラクティスに従ってください。

Shiseidoの公式Webサイトのように、視差スクロールと要素のアニメーション効果を実現する方法は?
または:
Shiseidoの公式Webサイトのようにスクロールするページを伴うアニメーション効果をどのように実現できますか? Shiseidoの公式Webサイトのように、視差スクロールと要素のアニメーション効果を実現する方法は? または: Shiseidoの公式Webサイトのようにスクロールするページを伴うアニメーション効果をどのように実現できますか? Apr 04, 2025 pm 05:36 PM

この記事の視差スクロールと要素のアニメーション効果の実現に関する議論では、Shiseidoの公式ウェブサイト(https://www.shisido.co.co.jp/sb/wonderland/)と同様の達成方法について説明します。

JavaScriptの進化:現在の傾向と将来の見通し JavaScriptの進化:現在の傾向と将来の見通し Apr 10, 2025 am 09:33 AM

JavaScriptの最新トレンドには、TypeScriptの台頭、最新のフレームワークとライブラリの人気、WebAssemblyの適用が含まれます。将来の見通しは、より強力なタイプシステム、サーバー側のJavaScriptの開発、人工知能と機械学習の拡大、およびIoTおよびEDGEコンピューティングの可能性をカバーしています。

JavaScriptを使用して、同じIDを持つArray要素を1つのオブジェクトにマージする方法は? JavaScriptを使用して、同じIDを持つArray要素を1つのオブジェクトにマージする方法は? Apr 04, 2025 pm 05:09 PM

同じIDを持つ配列要素をJavaScriptの1つのオブジェクトにマージする方法は?データを処理するとき、私たちはしばしば同じIDを持つ必要性に遭遇します...

Console.log出力の違い結果:なぜ2つの呼び出しが異なるのですか? Console.log出力の違い結果:なぜ2つの呼び出しが異なるのですか? Apr 04, 2025 pm 05:12 PM

Console.log出力の違いの根本原因に関する詳細な議論。この記事では、Console.log関数の出力結果の違いをコードの一部で分析し、その背後にある理由を説明します。 �...

See all articles