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

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