国产av日韩一区二区三区精品,成人性爱视频在线观看,国产,欧美,日韩,一区,www.成色av久久成人,2222eeee成人天堂

Jadual Kandungan
Perkara yang saya lakukan
Kod Dump!
Masalah / soalan
Rumah hujung hadapan web tutorial css Hanya berkongsi gulpfile saya

Hanya berkongsi gulpfile saya

Apr 13, 2025 am 10:00 AM

Hanya berkongsi gulpfile saya

Seolah -olah keluar dari biru, pemprosesan Teluk yang saya buat untuk laman web ini mula mempunyai keadaan perlumbaan. Saya akan menjalankan perintah jam tangan saya, menukar beberapa CSS, dan pemprosesan kadang -kadang akan meninggalkan beberapa fail tambahan yang dimaksudkan untuk dibersihkan semasa pemprosesan. Seperti tugas pembersihan berlaku sebelum fail mendarat di dalam sistem fail (atau sesuatu ... Saya tidak pernah sampai ke bahagian bawahnya).

Nevermind tentang spesifikasi pepijat itu. Saya fikir saya akan menyelesaikannya dengan menaik taraf perkara untuk menggunakan Gulp 4.x dan bukannya 3.x, dan menjalankan perkara-perkara dalam perintah Gulp.Series terbina dalam, yang saya fikir akan membantu (ia dilakukan).

Mendapatkan Gulp 4.x pergi adalah satu perjalanan untuk saya, yang melibatkan saya menyerah selama setahun , kemudian menunaikan perjuangan dan akhirnya mendapatkannya tetap. Masalah saya ialah Gulp 4 memerlukan versi CLI 2.x manakala Gulp 3, atas sebab apa pun, menggunakan versi 3.x. Pada dasarnya saya perlu menurunkan versi, tetapi selepas mencuba satu bilion perkara untuk melakukan itu, tidak ada yang kelihatan berfungsi, seperti terdapat versi hantu CLI 3.x pada mesin saya.

Saya pasti orang-orang baris perintah yang lebih bijak dapat menghisapnya lebih cepat daripada saya, tetapi ternyata perintah berjalan -v Gulp akan mendedahkan laluan fail di mana Gulp dipasang yang diturunkan/usr/local/share/npm/bin/gulp untuk saya, dan memadamkannya secara manual dari sana sebelum memasukkan semula versi terakhir yang bekerja.

Sekarang saya boleh menggunakan Gulp 4.x, saya menulis semula gulpfile.js saya ke dalam fungsi yang lebih kecil, masing-masing cukup terpencil dalam tanggungjawab. Kebanyakan ini cukup unik untuk persediaan saya di laman web ini, jadi ia tidak dimaksudkan untuk menjadi beberapa boilerplate untuk penggunaan generik. Saya hanya menerbitkan kerana pastinya akan membantu saya untuk merujuk ketika saya menciptanya.

Perkara yang saya lakukan

  • Menjalankan pelayan web (BrowserSync) untuk suntikan gaya dan auto-rfreshing
  • Menjalankan pemerhati fail (ciri gulp asli) untuk menjalankan tugas yang betul pada fail yang betul dan melakukan perkara di atas
  • Pemprosesan CSS
    • Sass> autoprefixer> minify
    • Cache Cache Stylesheet dari Templat (misalnya
    • Letakkan gaya.css di tempat yang betul untuk tema WordPress dan membersihkan fail hanya diperlukan semasa pemprosesan
  • Pemprosesan JavaScript
    • Babel> concatenate> minify
    • Cache penyemak imbas untuk s
    • Bersihkan fail yang tidak digunakan yang dibuat dalam pemprosesan
  • Pemprosesan SVG
    • Buat sprite svg (blok s
    • Namakannya sebagai fail sprite.php (jadi ia boleh dipasang php dalam templat) dan meletakkannya di tempat yang spesifik
  • Pemprosesan PHP
    • Kemas kini Panggilan Ajax di JavaScript ke Cache-bust apabila iklan berubah

Kod Dump!

 const gulp = memerlukan ("gulp"),
  BrowserSync = memerlukan ("penyemak imbas-sync"). Buat (),
  sass = memerlukan ("gulp-sass"),
  postcss = memerlukan ("gulp-postcss"),
  AutoPrefixer = memerlukan ("AutoPrefixer"),
  cssnano = memerlukan ("cssnano"),
  del = memerlukan ("del"),
  Babel = memerlukan ("Gulp-Babel"),
  minify = memerlukan ("Gulp-Minify"),
  concat = memerlukan ("gulp-concat"),
  Namakan semula = Memerlukan ("Gulp-Praame"),
  menggantikan = memerlukan ("Gulp-Replace"),
  svgsymbols = memerlukan ("gulp-svg-simbol"),
  svgmin = memerlukan ("gulp-svgmin");

Const Paths = {
  Gaya: {
    src: ["./scss/*.scss", "./art-direction/*.scss"],
    Dest: "./css/"
  },
  Skrip: {
    src: ["./js/*.js", "./js/libs/*.js", "! ./ Js/min/*. Js"],
    Dest: "./js/min"
  },
  SVG: {
    SRC: "./icons/*.svg"
  },
  php: {
    src: ["./*.php", "./ads/*.php", "./art-direction/*.php", "./parts/**/*.php"]
  },
  Iklan: {
    SRC: "./ads/*.php"
  }
};

/ * Gaya */
fungsi dostyles (selesai) {
  Kembali Gulp.Series (Gaya, MoveMainStyle, DeleteoldMainStyle, Selesai => {
    cacheBust ("./ header.php", "./");
    dilakukan ();
  }) (selesai);
}

gaya fungsi () {
  kembali gulp
    .src (paths.styles.src)
    .pipe (sass ())
    .on ("ralat", sass.logerror)
    .pipe (postcss ([autoprefixer (), cssnano ()]))
    .pipe (gulp.dest (paths.styles.dest))
    .pipe (browserSync.stream ());
}

fungsi MoveMainStyle () {
  kembali gulp.src ("./ css/style.css"). Pipa (gulp.dest ("./"));
}

fungsi DeleteoldMainStyle () {
  kembali del ("./ css/style.css");
}
/ * Gaya akhir */

/ * Skrip */
fungsi doskrip (dilakukan) {
  kembali gulp.series (
    preprocessjs,
    concatjs,
    Minifyjs,
    deleteartifactjs,
    Muat semula,
    selesai => {
      cacheBust ("./ Bahagian/footer-scripts.php", "./parts/");
      dilakukan ();
    }
  ) (selesai);
}

fungsi preprocessjs () {
  kembali gulp
    .src (paths.scripts.src)
    .pipe (
      babel ({
        Pratetap: ["@babel/env"],
        Plugin: ["@babel/plugin-proposal-class-properties"]
      })
    )
    .pipe (gulp.dest ("./ js/babel/"));
}

fungsi concatjs () {
  kembali gulp
    .src ([
      "JS/libs/jQuery.lazy.js",
      "JS/libs/jQuery.fitvids.js",
      "JS/libs/jQuery.resizable.js",
      "JS/libs/prism.js",
      "js/babel/sorotan-fix.js",
      "JS/Babel/Global.js"
    ])
    .pipe (concat ("global-concat.js"))
    .pipe (gulp.dest ("./ js/concat/"));
}

fungsi minifyjs () {
  kembali gulp
    .src (["./ js/babel/*. js", "./js/concat/*.js"])
    .pipe (
      minify ({
        ext: {
          SRC: ".js",
          min: ".min.js"
        }
      })
    )
    .pipe (gulp.dest (paths.scripts.dest));
}

fungsi deleteartifactjs () {
  kembali del ([
    "./js/babel",
    "./js/concat",
    "./js/min/*.js",
    "! ./ js/min/*. min.js"
  ]);
}
/ * Skrip akhir */

/ * Svg */
fungsi dosvg () {
  kembali gulp
    .src (paths.svg.src)
    .pipe (svgmin ())
    .pipe (
      svgsymbols ({
        Templat: ["lalai-svg"],
        svgattrs: {
          Lebar: 0,
          Ketinggian: 0,
          Paparan: "Tiada"
        }
      })
    )
    .PIPE (Namakan semula ("Ikon/Sprite/Icons.php"))
    .pipe (gulp.dest ("./"));
}
/ * Akhir svg */

/ * Perkara generik */
fungsi cachebust (src, dest) {
  var cbstring = tarikh baru () gettime ();
  kembali gulp
    .SRC (SRC)
    .pipe (
      ganti ( /cache_bust = \ d /g, fungsi () {
        kembali "cache_bust =" cbstring;
      })
    )
    .pipe (gulp.dest (dest));
}

fungsi tambah nilai (dilakukan) {
  browserSync.reload ();
  dilakukan ();
}

fungsi menonton () {
  BrowserSync.init ({
    Proksi: "csstricks.local"
  });
  gulp.watch (paths.styles.src, dostyles);
  gulp.watch (paths.scripts.src, doscripts);
  gulp.watch (paths.svg.src, dosvg);
  gulp.watch (paths.php.src, tambah nilai);
  gulp.watch (paths.ads.src, selesai => {
    cacheBust ("./ js/global.js", "./js/");
    dilakukan ();
  });
}

gulp.task ("lalai", menonton);

Masalah / soalan

  • Bahagian yang paling teruk ialah ia tidak memecahkan cache dengan bijak. Apabila CSS berubah, ia memecahkan cache pada semua stylesheets, bukan hanya yang relevan.
  • Saya mungkin hanya selaras ikon SVG dengan PHP termasuk () s pada masa akan datang dan bukannya berurusan dengan spriting.
  • Pemproses SVG memecahkan jika SVG asal mempunyai atribut lebar dan ketinggian, yang nampaknya salah.
  • Adakah berubah-ubah menjadi rangsangan kelajuan? Seperti dalam, hanya melihat fail yang telah berubah dan bukannya semua fail? Atau tidak perlu lagi?
  • Sekiranya saya memulakan semula Gulp pada perubahan gulpfile.js?
  • Pasti akan menjadi baik jika semua lib yang saya gunakan adalah bersesuaian ES6 supaya saya dapat mengimport barangan daripada harus bersekutu secara manual.

Sentiasa lebih banyak lagi yang boleh dilakukan. Sebaik-baiknya, saya hanya membuka sumber laman web ini, saya belum sampai di sana lagi.

Atas ialah kandungan terperinci Hanya berkongsi gulpfile saya. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn

Alat AI Hot

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

Video Face Swap

Video Face Swap

Tukar muka dalam mana-mana video dengan mudah menggunakan alat tukar muka AI percuma kami!

Alat panas

Notepad++7.3.1

Notepad++7.3.1

Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina

SublimeText3 versi Cina

Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1

Hantar Studio 13.0.1

Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

SublimeText3 versi Mac

SublimeText3 versi Mac

Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Apa itu 'menyekat CSS'? Apa itu 'menyekat CSS'? Jun 24, 2025 am 12:42 AM

CSS Blok halaman yang diberikan kerana pelayar melihat CSS dalam talian dan luaran sebagai sumber utama secara lalai, terutamanya dengan stylesheet yang diimport, header sejumlah besar CSS sebaris, dan gaya pertanyaan media yang tidak dapat dioptimumkan. 1. Ekstrak CSS kritikal dan membenamkannya ke HTML; 2. Kelewatan memuatkan CSS bukan kritikal melalui JavaScript; 3. Gunakan atribut media untuk mengoptimumkan pemuatan seperti gaya cetak; 4. Memampatkan dan menggabungkan CSS untuk mengurangkan permintaan. Adalah disyorkan untuk menggunakan alat untuk mengekstrak CSS utama, menggabungkan REL = "Preload" pemuatan asynchronous, dan menggunakan media yang ditangguhkan dengan munasabah untuk mengelakkan pemisahan yang berlebihan dan kawalan skrip kompleks.

Luaran vs CSS Dalaman: Apakah pendekatan terbaik? Luaran vs CSS Dalaman: Apakah pendekatan terbaik? Jun 20, 2025 am 12:45 AM

Thebestapproachforcssdependonstantheproject'ssspecificneeds.forlargerprojects, externalcssisbetterduetomaintainabilityability;

Adakah CSS saya mesti berada di bawah kes? Adakah CSS saya mesti berada di bawah kes? Jun 19, 2025 am 12:29 AM

Tidak, cssdoesnothavetobeinlowercase.however, menggunakanLowerCaseisRecommendorfendfor: 1) Consistencyandreadability, 2) Mengelakkaningerrorsinrelatedtechnologies, 3) potensiformanceBenefits, dan4) peningkatan yang lebih baik.

Kepekaan kes CSS: Memahami apa yang penting Kepekaan kes CSS: Memahami apa yang penting Jun 20, 2025 am 12:09 AM

Cssismostlycase-insensitive, buturlsandfontfamilynamesarecase-sensitif.1) propertiesandvalueslikecolor: merah; arenotcase-sensitif.2) urlsmustmatchtheserver'scase, mis.,

Apakah AutoPrefixer dan bagaimana ia berfungsi? Apakah AutoPrefixer dan bagaimana ia berfungsi? Jul 02, 2025 am 01:15 AM

AutoPrefixer adalah alat yang secara automatik menambah awalan vendor ke atribut CSS berdasarkan skop penyemak imbas sasaran. 1. Ia menyelesaikan masalah mengekalkan awalan secara manual dengan kesilapan; 2. Bekerja melalui borang pemalam postcss, menghuraikan CSS, menganalisis atribut yang perlu diawali, dan menjana kod mengikut konfigurasi; 3. Langkah-langkah penggunaan termasuk memasang pemalam, menetapkan senarai pelayar, dan membolehkan mereka dalam proses membina; 4. Nota termasuk tidak menambah awalan secara manual, menyimpan kemas kini konfigurasi, awalan tidak semua atribut, dan disyorkan untuk menggunakannya dengan preprocessor.

Apakah kaunter CSS? Apakah kaunter CSS? Jun 19, 2025 am 12:34 AM

Csscounterscanautomaticallynumbersectionsandlists.1) useCounter-resettoinitialize, counter-incrementToinCrease, andCounter () orcounters () todisplayvalues.2) CombinWithjavascriptfordynamicContentToenSureAccurateupdates.

CSS: Bilakah kes perkara (dan kapan tidak)? CSS: Bilakah kes perkara (dan kapan tidak)? Jun 19, 2025 am 12:27 AM

Dalam CSS, nama pemilih dan atribut adalah sensitif kes, manakala nilai, warna yang dinamakan, URL, dan atribut tersuai adalah sensitif kes. 1. Nama pemilih dan atribut adalah kes-tidak sensitif, seperti warna latar belakang dan warna latar belakang adalah sama. 2. Warna heksadesimal dalam nilai adalah sensitif kes, tetapi warna bernama adalah sensitif kes, seperti merah dan merah tidak sah. 3. URL adalah sensitif kes dan boleh menyebabkan masalah pemuatan fail. 4. Sifat tersuai (pembolehubah) adalah sensitif kes, dan anda perlu memberi perhatian kepada konsistensi kes apabila menggunakannya.

Apakah fungsi conic-gradient ()? Apakah fungsi conic-gradient ()? Jul 01, 2025 am 01:16 AM

Function-gradient () functionIncsscreatesculculargradientsthatrotatecolorstopsaroundroentroint.1.ISIISIDEALFORPIECHARTS, Progressindicators, Colorwheels, andDecorativeBackgrounds.2.itworksByDefiningColorStopsatSpecificles, OpsticalStarting

See all articles