मिनी ऐप्लिकेशन कॉम्पोनेंट

वेब कॉम्पोनेंट को इस उम्मीद के साथ शुरू किया गया था कि डेवलपर इन्हें एक साथ जोड़कर, इन पर बेहतरीन ऐप्लिकेशन बना पाएंगे. ऐसे एटमिक कॉम्पोनेंट के उदाहरणों में, GitHub का टाइम-एलिमेंट, स्टीफ़न जूडिस का वेब-विटल्स-एलिमेंट या Google का डार्क मोड टॉगल शामिल है. हालांकि, पूरी तरह से डिज़ाइन किए गए सिस्टम के लिए, मैंने देखा है कि लोग एक ही वेंडर के कॉम्पोनेंट के एक साथ काम करने वाले सेट पर भरोसा करना पसंद करते हैं. उदाहरणों की अधूरी सूची में SAP के UI5 वेब कॉम्पोनेंट, पॉलीमर एलिमेंट, Vaadin के एलिमेंट, Microsoft के FAST, मटीरियल वेब कॉम्पोनेंट, AMP कॉम्पोनेंट वगैरह शामिल हैं. इस लेख के दायरे में न आने वाली कई चीज़ों की वजह से, कई डेवलपर ने React, Vue.js, Ember.js जैसे फ़्रेमवर्क भी शामिल किए हैं. उनके बजाय, डेवलपर को इनमें से कोई भी विकल्प चुनने की आज़ादी देने के बजाय (या आपके नज़रिए के आधार पर, डेवलपर को एक तकनीकी कॉम्पोनेंट देने के लिए मज़बूत करना पड़ता है.

मिनी ऐप्लिकेशन में कॉम्पोनेंट

इन कॉम्पोनेंट को ऊपर बताई गई किसी भी कॉम्पोनेंट लाइब्रेरी की तरह समझा जा सकता है. उपलब्ध कॉम्पोनेंट की खास जानकारी पाने के लिए, WeChat की कॉम्पोनेंट लाइब्रेरी, ByteDance के कॉम्पोनेंट, Alipay के कॉम्पोनेंट, Baidu के, और क्विक ऐप्लिकेशन के कॉम्पोनेंट ब्राउज़ किए जा सकते हैं.

पहले मैंने बताया था कि उदाहरण के लिए, WeChat का <image> एक वेब कॉम्पोनेंट है. हालांकि, यह ज़रूरी नहीं है कि ये सभी कॉम्पोनेंट, तकनीकी रूप से वेब कॉम्पोनेंट हों. <map> और <video> जैसे कुछ कॉम्पोनेंट, ओएस में पहले से मौजूद कॉम्पोनेंट के तौर पर रेंडर किए जाते हैं. ये वेबव्यू के ऊपर लेयर में दिखते हैं. डेवलपर को, लागू करने के तरीके की जानकारी नहीं दी जाती. इसे किसी दूसरे कॉम्पोनेंट की तरह प्रोग्राम किया जाता है.

हमेशा की तरह, जानकारी अलग-अलग होती है, लेकिन प्रोग्रामिंग के सभी कॉन्सेप्ट, सुपर ऐप्लिकेशन उपलब्ध कराने वाली सभी कंपनियों के लिए एक जैसे होते हैं. डेटा बाइंडिंग एक अहम सिद्धांत है, जैसा कि पहले मार्कअप भाषाओं में दिखाया गया है. आम तौर पर, कॉम्पोनेंट को फ़ंक्शन के हिसाब से ग्रुप में बांटा जाता है. इसलिए, काम के लिए सही कॉम्पोनेंट को ढूंढना आसान होता है. यहां Alipay के कैटगरी के हिसाब से बांटने का उदाहरण दिया गया है. यह उदाहरण, अन्य वेंडर के कॉम्पोनेंट ग्रुपिंग से मिलता-जुलता है.

  • कंटेनर देखना
    • view
    • swiper
    • scroll-view
    • cover-view
    • cover-image
    • movable-view
    • movable-area
  • बुनियादी कॉन्टेंट
    • text
    • icon
    • progress
    • rich-text
  • फ़ॉर्म के कॉम्पोनेंट
    • button
    • form
    • label
    • input
    • textarea
    • radio
    • radio-group
    • checkbox
    • checkbox-group
    • switch
    • slider
    • picker-view
    • picker
  • नेविगेशन
    • navigator
  • मीडिया कॉम्पोनेंट
    • image
    • video
  • कैनवस
    • canvas
  • मैप
    • map
  • कॉम्पोनेंट खोलें
    • web-view
    • lifestyle
    • contact-button
  • सुलभता
    • aria-component

यहां, a:for डायरेक्टिव (सूची को रेंडर करना देखें) में इस्तेमाल किए गए Alipay के <image> को देखा जा सकता है. यह डायरेक्टिव, index.js में दिए गए इमेज डेटा कलेक्शन पर लूप करता है.

/* index.js */
Page({
  data
: {
    array
: [
     
{
        mode
: "scaleToFill",
        text
: "scaleToFill",
     
},
     
{
        mode
: "aspectFit",
        text
: "aspectFit",
     
},
   
],
    src
: "https://images.example.com/sample.png",
 
},
  imageError
(e) {
    console
.log("image", e.detail.errMsg);
 
},
  onTap
(e) {
    console
.log("image tap", e);
 
},
  imageLoad
(e) {
    console
.log("image", e);
 
},
});
<!-- index.axml -->
<view class="page">
 
<view class="page-section" a:for="{{array}}" a:for-item="item">
   
<view class="page-section-demo" onTap="onTap">
     
<image
       
class="image"
       
mode="{{item.mode}}"
        onTap
="onTap"
       
onError="imageError"
       
onLoad="imageLoad"
       
src="{{src}}"
       
lazy-load="true"
       
default-source="https://images.example.com/loading.png"
     
/>
   
</view>
 
</view>
</view>

item.mode को mode एट्रिब्यूट से, src को src एट्रिब्यूट से, और एक ही नाम के फ़ंक्शन के लिए तीन इवेंट हैंडलर onTap, onError, और onLoad को डेटा बाइंडिंग पर ध्यान दें. पहले दिखाए गए तरीके के मुताबिक, <image> टैग अंदरूनी तौर पर <div> में बदल जाता है. इसमें इमेज के फ़ाइनल डाइमेंशन का प्लेसहोल्डर, धीमे लोड होने की सुविधा (ज़रूरी नहीं), डिफ़ॉल्ट सोर्स वगैरह शामिल होते हैं.

कॉम्पोनेंट के कॉन्फ़िगरेशन के सभी उपलब्ध विकल्प, दस्तावेज़ में दिए गए हैं. दस्तावेज़ों में एम्बेड किए गए सिम्युलेटर के साथ कॉम्पोनेंट की झलक, कोड को तुरंत समझने लायक बनाती है.

एम्बेड किए गए कॉम्पोनेंट की झलक के साथ Alipay कॉम्पोनेंट का दस्तावेज़. इसमें सिम्युलेटर के साथ कोड एडिटर दिखाया गया है, जो सिम्युलेट किए गए iPhone 6 पर रेंडर किए गए कॉम्पोनेंट को दिखाता है.
एम्बेड किए गए कॉम्पोनेंट की झलक के साथ, Alipay कॉम्पोनेंट का दस्तावेज़.
अलग-अलग ब्राउज़र टैब में चल रहे Alipay कॉम्पोनेंट की झलक. इसमें सिम्युलेटर के साथ कोड एडिटर दिख रहा है. यह सिम्युलेटर, iPhone 6 पर रेंडर किए गए कॉम्पोनेंट को दिखाता है.
Alipay कॉम्पोनेंट की झलक, अपने टैब में पॉप आउट हुई.

हर कॉम्पोनेंट में एक क्यूआर कोड भी होता है, जिसे Alipay ऐप्लिकेशन से स्कैन किया जा सकता है. इससे, कॉम्पोनेंट के उदाहरण को एक छोटे से उदाहरण में खोला जा सकता है.

दस्तावेज़ में दिए गए क्यूआर कोड को स्कैन करने के बाद, Alipay के `image` कॉम्पोनेंट की असल डिवाइस पर झलक.
Docs में दिए गए क्यूआर कोड लिंक की मदद से, असली डिवाइस पर Alipay <image> कॉम्पोनेंट की झलक देखी जा सकती है.

डेवलपर, मालिकाना हक वाली यूआरआई स्कीम antdevtool-tiny:// का इस्तेमाल करके, दस्तावेज़ों से सीधे Alipay DevTools IDE पर जा सकते हैं. इससे दस्तावेज़ को सीधे तौर पर, इंपोर्ट किए जाने वाले मिनी ऐप्लिकेशन प्रोजेक्ट से लिंक किया जा सकता है, ताकि डेवलपर तुरंत कॉम्पोनेंट का इस्तेमाल शुरू कर सकें.

कस्टम कॉम्पोनेंट

वेंडर से मिले कॉम्पोनेंट का इस्तेमाल करने के अलावा, डेवलपर कस्टम कॉम्पोनेंट भी बना सकते हैं. यह कॉन्सेप्ट, WeChat, ByteDance, Alipay, Baidu, और Quick App के लिए उपलब्ध है. उदाहरण के लिए, Baidu के कस्टम कॉम्पोनेंट में चार फ़ाइलें होती हैं, जो एक ही फ़ोल्डर में होनी चाहिए: custom.swan, custom.css, custom.js, और custom.json.

custom.json फ़ाइल, फ़ोल्डर के कॉन्टेंट को कस्टम कॉम्पोनेंट के तौर पर दिखाती है.

{
 
"component": true
}

फ़ाइल custom.swan में मार्कअप और custom.css में सीएसएस है.

<view class="name" bindtap="tap">{{name}} {{age}}</view>
.name {
 
color: red;
}

custom.js फ़ाइल में लॉजिक शामिल है. कॉम्पोनेंट के लाइफ़साइकल से जुड़े फ़ंक्शन ये हैं: attached(), detached(), created(), और ready(). यह कॉम्पोनेंट, show() और hide() जैसे पेज के लाइफ़साइकल इवेंट पर भी प्रतिक्रिया दे सकता है.

Component({
  properties
: {
    name
: {
      type
: String,
      value
: "swan",
   
},
 
},
  data
: {
    age
: 1,
 
},
  methods
: {
    tap
: function () {},
 
},
  lifetimes
: {
    attached
: function () {},
    detached
: function () {},
    created
: function () {},
    ready
: function () {},
 
},
  pageLifetimes
: {
    show
: function () {},
    hide
: function () {},
 
},
});

इसके बाद, कस्टम कॉम्पोनेंट को index.json में इंपोर्ट किया जा सकता है. इंपोर्ट की कुंजी से नाम तय होता है (यहां: "custom"), जिसका इस्तेमाल index.swan में कस्टम कॉम्पोनेंट के साथ किया जा सकता है.

{
 
"usingComponents": {
   
"custom": "/components/custom/custom"
 
}
}
<view>
 
<custom name="swanapp"></custom>
</view>

धन्यवाद

इस लेख की समीक्षा, जो मेडली, किस बेस्केस, मिलिका मिहाइलिया, ऐलन केंट, और कीथ गु ने की.