Kısaca Grunt

Grunt bir görev çalıştırıcısı. Web geliştirme sürecinde ihtiyacınız olan operasyonları otomatize etmenize yarayacak bir araç. Daha çok platforma dönüşmüş olan grunt, yüzlerce eklentiyle istediğiniz forma sokabileceğiniz bir yapılandırma aracı. Hızlıca bir örnek vereceğim. Basit bir web sitesi hazırlıyorsunuz ve stillerinizi css yerine less ile yazdınız, javascriptlerinizi cosnole.log debug satırlarıyla ve bir sürü yorum ile yazdınız. Sitenizi her yayına alacagınızda bir toparlama ve paketleme işi yapmanız gerekiyor, lessilerinizi css'lere derlemek, belki cssmin gibi ufaltma operasyonuna sokmak, imajlarınızı sıkıştırmanız, javascriptlerinizi temizleyip küçültmeniz belki birden fazla kaynağı tek dosyada birleştirmeyi isteyeceksiniz. Her değişiklik yaptığınızda bu işlemleri tekrarlamanıza imkan yok. İşte bu noktada grunt devreye giriyor.

Grunt ile neler yapabilirsiniz?

Sonu yok çünkü kendi eklentilerinizi yazarak node.js yeteneklerini kullanarak yapamayacağınız şey yok. Ama eklenti veritabanından erişebileceğiniz o kadar çok şey var ki.
- Less, Scss, Sass vb... herhangi bir css derleme işinizi
- Kod validasyonu (css, js, html)
- Imaj optimizasyonu
- Birden fazla javascript veya css kaynağını birleştirme
- Css veya javascript sıkıştırma
- Kodunuzdaki yorumları, debug için geriye kalan artıkları temizleme
- Kaynak versiyonlama

Daha sayamadığım bir çok operasyonu grunt ile farklı kombinasyonlarda hazırlamanız mümkün.

Örnek

Versiyonlamayı denemek için kendime bir örnek kod hazırladım ve github'da paylaştım. Basit bir css javascript projesinde kodumu yayınlamadan önce bütün css ve javascript kaynaklarımı sıkıştırıp adlarını versiyonlamarak yayındaki tüm dosyaların en taze kodu kullanmasını sağlamak için grunt kullandım. Projeyehttps://github.com/mfyz/grunt-release-boilerplate adresinden erişebilirsiniz.

Grunt hakkinda daha fazla bilgiye sitesinden erişebilirsiniz:http://gruntjs.com/

Popüler Etiketler

mysql sql optimizasyon analyse procedure regex örnek kod db database service free api google social media css mail newsletter subscription css3 html ruffles wanda facebook oyun ios iphone ipad apple app store store in-app purchase purchase verification integration storekit itunes connect itunes php server session cookie htaccess url windows ingilizce mfyz proje kampanya tool wordpress rss form input textarea select ui ux login webkit apache job cms lifestream search ubuntu cache dokuman kurulum query injection phpstorm jetbrains pgsql mssql ide editor javascript js jquery plugin box twitter istatistik insanlar digital medya network app developer linux konsol radio style xml nedir html5 mobile blog mootools ajax xmlhttprequest iOS button switch parse pear mdb2 prepare execute web app open source link less sosyal spam connect startups music tebrik coding ie support browser table nasıl code development widget auth screen terminal route router mod_rewrite bootstrap opengraph fql optimization framework gimp howto portfolio lisans language sitemap seo player license generator date diff zaman tarih macosx compile compiler on-the-fly osx workspace internet explorer calendar http meta ipucu firefox logo notebook laptop doritos tytz assets imza signature icon ikon grafik download xhtml while kontrol yapıları if browsers banner svn subversion internet fstab ntfs pharma hack export statistics graph share kitap www subdomain redirect crossdomain wireless applications chart icons git version control deployment object design