पब्लिश करने की तारीख: 28 फ़रवरी, 2014
वेब डेवलपमेंट की सबसे अच्छी बात यह है कि इसमें कई तरह के टूल उपलब्ध होते हैं. इनका इस्तेमाल करके, अपने वर्कफ़्लो को बेहतर बनाया जा सकता है.
इनमें से एक टूल का उदाहरण Grunt है. यह एक JavaScript टास्क रनर है, जिसकी मदद से अपने वेब ऐप्लिकेशन पर टास्क तय किए जा सकते हैं. जैसे, Sass को कॉम्पाइल करना और लाइव सर्वर शुरू करना. इसके अलावा, प्रोडक्शन के लिए तैयार बिल्ड बनाने से पहले, इमेज को कंप्रेस करना, JavaScript को छोटा करना, और JSHint को चलाना.
Yeoman एक टूल है, जो वेब ऐप्लिकेशन बनाने, बायलरप्लेट जनरेट करने, Bower और npm से लाइब्रेरी लाने, और पहले से तय किए गए टास्क के साथ Grunt फ़ाइल बनाने में मदद करता है.
इस ट्यूटोरियल में, Yeoman का इस्तेमाल करके एक नया बुनियादी वेब ऐप्लिकेशन बनाया जाता है. इसके बाद, अपना वेब ऐप्लिकेशन बनाने के लिए, Android Studio के बिल्ड सिस्टम (Gradle) को Grunt के साथ इंटिग्रेट किया जाता है. आपको ब्राउज़र में अपने ऐप्लिकेशन की जांच करने के लिए, एक स्थानीय लाइव रीलोड सर्वर लॉन्च करने के लिए, Grunt टास्क भी सेट अप करने होंगे. इससे, हर बार एचटीएमएल, सीएसएस या JavaScript फ़ाइल में बदलाव करने पर, आपको पेज को मैन्युअल तौर पर रीफ़्रेश करने की ज़रूरत नहीं पड़ेगी.
ज़रूरी शर्तें
शुरू करने से पहले, आपको कुछ ज़रूरी शर्तें पूरी करनी होंगी:
- Yeoman इंस्टॉल करें: https://github.com/yeoman/yeoman/wiki/Getting-Started
- Android Studio इंस्टॉल करें: https://developer.android.com/sdk/installing/studio.html
पहला चरण. वेबव्यू की मदद से, Android Studio में नया प्रोजेक्ट बनाना
शुरू करने की गाइड में, ऐसा करने का पूरा तरीका बताया गया है.
दूसरा चरण. वेब ऐप्लिकेशन के कॉन्टेंट के लिए सबडायरेक्ट्री बनाना
प्रोजेक्ट बनाने के बाद, एक नई टॉप लेवल डायरेक्ट्री बनाएं. Android Studio में, प्रोजेक्ट फ़ोल्डर पर राइट क्लिक करें और नया > डायरेक्ट्री चुनें.
डायरेक्ट्री को webapp
नाम दें.
तीसरा चरण. अपनी नई डायरेक्ट्री में Yeoman प्रोजेक्ट बनाना
टर्मिनल cd
में, प्रोजेक्ट की webapp
डायरेक्ट्री पर जाएं.
cd <path-to-project>/webapp/
इसके बाद, Yeoman की मदद से नया वेब ऐप्लिकेशन बनाएं:
yo webapp
प्रोजेक्ट के विकल्प चुनने के लिए, स्क्रीन पर दिए गए निर्देशों का पालन करें. आपकी मशीन पर npm को इंस्टॉल करने के तरीके के आधार पर, आपको sudo npm install
चलाना पड़ सकता है.
अगले चरण पर जाने से पहले, यहां दिया गया निर्देश चलाकर ऐप्लिकेशन की जांच करें:
grunt server
आपके ब्राउज़र में एक नया टैब खुलेगा. यह टैब, Grunt से शुरू किए गए लोकल सर्वर से कनेक्ट होगा. अगर प्रोजेक्ट में मौजूद किसी एचटीएमएल, सीएसएस या JavaScript फ़ाइल में बदलाव किया जाता है, तो पेज अपने-आप रीलोड और अपडेट हो जाता है.
grunt build
को चलाने पर, एक नई डायरेक्ट्री dist
बन जाती है. साथ ही, आपके वेब ऐप्लिकेशन को इस फ़ोल्डर में कंप्रेस, ऑप्टिमाइज़, और प्रोडक्शन के लिए तैयार किया जाता है.
चरण 4. Gradle बिल्ड को कॉन्फ़िगर करना
अपनी webapp
डायरेक्ट्री में, build.gradle
नाम की एक नई फ़ाइल बनाएं.
अपनी नई build.gradle
फ़ाइल में, ये चीज़ें जोड़ें:
import org.apache.tools.ant.taskdefs.condition.Os
task buildWebApp(type: Exec) {
executable = Os.isFamily(Os.FAMILY_WINDOWS) ? "grunt.cmd" : "grunt"
args = ["build"]
}
इससे buildWebApp
नाम का एक नया टास्क बन जाएगा. साथ ही, यह टास्क पहले से तय किए गए टाइप Exec
का होगा.
इसके बाद, मौजूदा ओएस के आधार पर, Exec
में executable
वैरिएबल को काम के grunt कमांड पर सेट करें. args
को "build"
पर सेट किया गया है, जिसका मतलब है कि grunt build
को कमांड लाइन पर चलाया जा रहा है. आखिर में, सबसे ऊपर मौजूद इंपोर्ट का इस्तेमाल, Os.isFamily(Os.FAMILY_WINDOWS)
का इस्तेमाल करने के लिए किया जाता है.
इस नए टास्क का इस्तेमाल करने से पहले, हमें प्रोजेक्ट को नई build.gradle
फ़ाइल के बारे में बताना होगा.
रूट डायरेक्ट्री में settings.gradle
खोलें और यह लाइन जोड़ें:
include ':webapp'
पाँचवाँ चरण. Android ऐप्लिकेशन बनाते समय अपना वेब ऐप्लिकेशन बनाना
वेब ऐप्लिकेशन को बिल्ड करें और फिर ऐप्लिकेशन को अपने Android ऐप्लिकेशन की assets
डायरेक्ट्री में कॉपी करें.
नीचे दिए गए कोड को Android ऐप्लिकेशन build.gradle
फ़ाइल में कॉपी करें:
task copyWebApplication(type: Copy) {
from '../webapp/dist'
into 'src/main/assets/www'
}
task deleteWebApplication(type: Delete) {
delete 'src/main/assets/www'
}
copyWebApplication.dependsOn ':webapp:buildWebApp'
copyWebApplication.dependsOn deleteWebApplication
android.applicationVariants.all { variant ->
tasks.getByPath(":${project.name}:assemble${variant.buildType.name.capitalize()}").dependsOn copyWebApplication
}
आइए, इसकी हर चीज़ की जांच करते हैं.
task copyWebApplication
task copyWebApplication(type: Copy) {
from '../webapp/dist'
into 'src/main/assets/www'
}
यह Copy
टास्क, आपके ऐप्लिकेशन को webapp/dist
डायरेक्ट्री से कॉपी करता है. हमें फ़ाइलों को src/main/assets/www
में कॉपी करना है. अगर ज़रूरी डायरेक्ट्री मौजूद नहीं है, तो यह टास्क ज़रूरी फ़ाइल स्ट्रक्चर भी बनाता है.
task deleteWebApplication
task deleteWebApplication(type: Delete) {
delete 'src/main/assets/www'
}
मिटाने का यह टास्क, assets/www
डायरेक्ट्री में मौजूद सभी फ़ाइलों को मिटा देता है.
copyWebApplication.dependsOn
copyWebApplication.dependsOn ':webapp:buildWebApp'
copyWebApplication.dependsOn deleteWebApplication
इसकी पहली लाइन से पता चलता है कि copyWebApplication
, हमारे वेब ऐप्लिकेशन की build.gradle
फ़ाइल के buildWebApp
टास्क पर निर्भर है.
दूसरी लाइन से पता चलता है कि deleteWebApplication
टास्क पर निर्भरता है.
दूसरे शब्दों में, assets
डायरेक्ट्री में किसी भी फ़ाइल को कॉपी करने से पहले,
पक्का करें कि हम वेब ऐप्लिकेशन बना लें और assets
डायरेक्ट्री के मौजूदा कॉन्टेंट को भी मिटा दें.
android.applicationVariants.all
android.applicationVariants.all { variant ->
tasks.getByPath(":${project.name}:assemble${variant.buildType.name.capitalize()}").dependsOn copyWebApplication
}
यह टास्क, आपके ऐप्लिकेशन के हर वर्शन के लिए, आपके प्रोजेक्ट के सभी बिल्ड की डिपेंडेंसी बताता है. यहां यह copyWebApplication
को चलाने के लिए, assemble
टास्क पर डिपेंडेंसी सेट करता है.
assemble
टास्क, प्रोजेक्ट का आउटपुट इकट्ठा करते हैं. इसलिए, वेब ऐप्लिकेशन को पहले Android प्रोजेक्ट में कॉपी करना होगा.
छठा चरण. पक्का करना कि सब कुछ ठीक से काम कर रहा है
Android Studio में, आपके Android ऐप्लिकेशन src
फ़ोल्डर में कोई assets
डायरेक्ट्री नहीं होनी चाहिए.
index.html
पेज का इस्तेमाल करने के लिए, वेबव्यू को सेट करें:
mWebView.loadUrl("file:///android_asset/www/index.html");
चलाएं पर क्लिक करें और अपने ऐप्लिकेशन को बिल्ड होने दें. आपको www
सबडायरेक्ट्री में, अपने वेब ऐप्लिकेशन के साथ assets
डायरेक्ट्री दिखेगी.
सातवां चरण. लाइव सर्वर बनाना और लाइव रीलोड करना
लाइव रीलोडिंग की सुविधा, वेब ऐप्लिकेशन में तुरंत बदलाव करने के लिए काफ़ी मददगार हो सकती है. इसे चालू करने के लिए, अपने ऐप्लिकेशन के लिए दो "प्रॉडक्ट फ़्लेवर" बनाए जा सकते हैं: एक लाइव सर्वर वर्शन और एक स्टैटिक वर्शन. इसमें वेब कॉन्टेंट को Android ऐप्लिकेशन में पैकेज किया जाता है.
अपने Android ऐप्लिकेशन के build.gradle
में, android
एलिमेंट के आखिर में ये लाइनें जोड़ें:
android {
...
defaultConfig {
...
}
productFlavors {
staticbuild {
packageName "com.google.chrome.myapplication"
}
liveserver {
packageName "com.google.chrome.myapplication.liveserver"
}
}
}
Gradle अब आपको अपने ऐप्लिकेशन का एक वर्शन, लाइव सर्वर पैकेज के नाम और एक सामान्य पैकेज के नाम के साथ बनाने की सुविधा देता है. यह देखने के लिए कि यह काम करता है या नहीं, Gradle फ़ाइलों के साथ प्रोजेक्ट सिंक करें पर क्लिक करें. यह विकल्प, सबसे ऊपर मौजूद बार में चालू करें बटन के बगल में होता है.
इसके बाद, Android Studio के सबसे नीचे बाएं कोने में मौजूद बिल्ड वैरिएंट देखें. इससे आपको यह पता चलता है कि आपके ऐप्लिकेशन के कौनसे वर्शन बनाए जा सकते हैं.
हर productFlavor
के लिए, डीबग और रिलीज़ वर्शन होते हैं. ये वर्शन, Gradle के लिए Android प्लग इन आपको डिफ़ॉल्ट रूप से देता है. इससे यह तय होता है कि बिल्ड, डीबग बिल्ड होना चाहिए या Play Store पर डिप्लॉय करने के लिए रिलीज़ बिल्ड.
अब आपके पास दो वर्शन हैं, लेकिन फ़िलहाल वे अलग-अलग काम नहीं करते.
चरण 8. लाइव सर्वर से लोड करना
अब, अपने ऐप्लिकेशन को कॉन्फ़िगर करें, ताकि वह आपके बनाए गए प्रॉडक्ट के फ़्लेवर के आधार पर, कोई दूसरा यूआरएल लोड कर सके.
आपके Android ऐप्लिकेशन में, सभी प्रॉडक्ट फ़्लेवर के लिए सामान्य फ़ाइलें src/main
में मौजूद होती हैं. किसी प्रॉडक्ट फ़्लेवर के लिए खास कोड या रिसॉर्स जोड़ने के लिए, src
में एक और डायरेक्ट्री बनाएं. इस डायरेक्ट्री का नाम, productFlavor
जैसा ही होना चाहिए. जब उस बिल्ड वैरिएंट के लिए बिल्ड किया जाता है, तो Gradle और Android प्लग इन, src/main
में मौजूद फ़ाइलों के साथ इन अतिरिक्त फ़ाइलों को मर्ज कर देते हैं.
यूआरएल को स्ट्रिंग रिसॉर्स के तौर पर तय करें और हार्ड कोड किए गए यूआरएल के बजाय, अपने कोड में उस रिसॉर्स का इस्तेमाल करें.
src/liveserver
औरsrc/staticbuild
फ़ोल्डर बनाएं.liveserver
फ़ोल्डर में,res
नाम का नया फ़ोल्डर बनाएं. इसमेंvalues
नाम का सब-फ़ोल्डर भी बनाएं. इसके अंदर,config.xml
नाम की फ़ाइल बनाएं.staticbuild
फ़ोल्डर के लिए भी यही तरीका दोहराएं.अपनी कॉन्फ़िगरेशन फ़ाइलों में,
src/liveserver/res/values/config.xml
में ये लाइनें जोड़ें:<?xml version="1.0" encoding="utf-8"?> <resources> <string name="init_url">https://<Your Local Machine IP Address>:9000</string> </resources>
src/staticbuild/res/values/config.xml
में यह ब्लॉक जोड़ें:<?xml version="1.0" encoding="utf-8"?> <resources> <string name="init_url">file:///android_asset/www/index.html</string> </resources>
अपने वेबव्यू को इन कॉन्फ़िगरेशन फ़ाइलों से
init_url
का इस्तेमाल करने के लिए सेट करें.mWebView.loadUrl(getString(R.string.init_url));
liveserver/AndroidManifest.xml
मेंAndroidManifest.xml
नाम की एक नई फ़ाइल बनाएं और ये लाइनें जोड़ें:<?xml version="1.0" encoding="utf-8"?> <manifest xmlns:android="https://schemas.android.com/apk/res/android"> <uses-permission android:name="android.permission.INTERNET" /> </manifest>
इससे
liveserver
बिल्ड के लिए, इंटरनेट की अनुमति जुड़ जाती है.webapp/Gruntfile.js
में जाकर, यह ढूंढें:connect: { options: { port: 9000, livereload: 35729, // change this to '0.0.0.0' to access the server from outside hostname: **'localhost'** }, ... }
localhost
को0.0.0.0
से बदलें, ताकि आपके लोकल सर्वर को लोकल नेटवर्क से ऐक्सेस किया जा सके:connect: { options: { port: 9000, livereload: 35729, // change this to '0.0.0.0' to access the server from outside hostname: '**0.0.0.0'** }, ... }
किए गए बदलावों की जांच करने के लिए:
लाइव सर्वर शुरू करने के लिए:
grunt server
Android Studio में, बिल्ड वैरिएंट सेक्शन में, LiveserverDebug चुनें. इसके बाद, चालू करें पर क्लिक करें.
आपके पास अपने एचटीएमएल, सीएसएस, और JavaScript कॉन्टेंट में बदलाव करने की सुविधा होनी चाहिए. साथ ही, ब्राउज़र में बदलाव तुरंत दिखने चाहिए.
अब आपके पास अपने ऐप्लिकेशन के दो वर्शन होंगे: Grunt सर्वर से लाइव रीलोड वाला डेवलपमेंट वर्शन और Android ऐप्लिकेशन में स्थानीय तौर पर पैकेज किया गया स्टैटिक वर्शन.