स्नेहा टच - अपलोड और डाउनलोड करें

स्नेहा टच अजाक्स और अजाक्स 2 विकास के साथ काम करने के लिए एक्सएचआर 2 कॉन्फ़िगरेशन प्रदान करता है।

XHR2 xmlHttpRequest स्तर 2 है, जो सर्वर से डेटा का अनुरोध करने के लिए उपयोग किया जाता है। किसी भी वेब एप्लिकेशन के लिए, डेटा सर्वर पर रहता है और पेज लोड होने के बाद, डेटा को Ajax अनुरोधों की मदद से सर्वर से एक्सेस किया जाना चाहिए।

Sencha टच में XHR2 प्रगति बार सुविधा प्रदान करता है, जो उपयोगकर्ता को किसी विशेष अनुरोध के लिए हस्तांतरित डेटा की मात्रा दिखाता है। XHR2 नया जोड़ा गया है, इसलिए हमें यह जांचने की आवश्यकता है कि ब्राउज़र इसका समर्थन करता है या नहीं।

यह जाँचने के लिए फ़ंक्शन है कि क्या ब्राउज़र XHR2 का समर्थन करता है -

if (Ext.feature.has.XHR2) {
   // Here we can write functionality to work if browser supports XHR2 
}

हम यह भी जांच सकते हैं कि XHR2 के साथ प्रगतिशील अपलोड ब्राउज़र द्वारा समर्थित है या नहीं।

if (Ext.feature.has.XHRUploadProgress) {
   // Here we can write functionality to work if browser supports progressive uploads
}

Sencha Touch में विभिन्न नए XHR2 फीचर शामिल किए गए हैं।

अनु क्रमांक सुविधाएँ और विवरण
1

XHR2: true

यह अनुप्रयोग में XHR2 कार्यक्षमता को सक्षम और अक्षम करने के लिए उपयोग किया जाता है।

2

Ext.field.File

नए फ़ाइल फ़ील्ड को फ़ील्ड के प्रकार के बारे में और अधिक जानकारी देने के लिए जोड़ा जाता है।

3

Ext.field.FileInput

यह FileInput प्रदान करने के लिए।

4

Ext.progressIndicator

यह प्रगति बार के संदर्भ में हस्तांतरित डेटा का सटीक प्रतिशत प्रदान करना है।

5

xtype: fileinput

FileInput वर्ग का उदाहरण बनाने के लिए।

6

xtype: filefield

फ़ाइल वर्ग का उदाहरण बनाने के लिए।

7

responseType : value

यह पैरामीटर पाठ, दस्तावेज़, बूँद आदि के रूप में विभिन्न प्रकार की प्रतिक्रियाओं की अनुमति देता है।

पैरामीटर और बिना पैरामीटर के सरल अजाक्स अनुरोध भेजने के लिए निम्नलिखित उदाहरण हैं और अजाक्स का उपयोग करके फाइलें अपलोड करना।

मापदंडों के बिना सरल अजाक्स अनुरोध - सफलता

<!DOCTYPE html>
<html>
   <head>
      <link href = "https://cdn.sencha.com/touch/sencha-touch-2.4.2/resources/css/sencha-touch.css" rel = "stylesheet" />
      <script type = "text/javascript" src = "https://cdn.sencha.com/touch/sencha-touch-2.4.2/sencha-touch-all.js"></script>
      <script type = "text/javascript">
         Ext.setup({
            requires: [ 'Ext.Panel', 'Ext.Button', 'Ext.form.Panel'], onReady: function() {
               var request = {
                  url: 'https://www.tutorialspoint.com/sencha_touch/index.htm',
                  method: 'POST',
                  xhr2: true,
                  success: function(response) {
                     Ext.Msg.alert('Ajax call successful');
                  },
                  failure: function(response) {
                     Ext.Msg.alert('Ajax call failed');
                  }
               };
               Ext.Viewport.add({
                  xtype:"panel",
                  layout:"vbox",
                  fullscreen:true,
                  items: [
                     {
                        xtype:"button",
                        text: "Ajax",
                        ui: 'confirm',
                        handler: function(){
                           Ext.Ajax.request(request);
                        }
                     }
                  ]
               });
            }
         });
      </script>
   </head>
   <body>
   </body>
</html>

यह निम्नलिखित परिणाम का उत्पादन करेगा -

उपरोक्त उदाहरण सफलता ajax कॉल दिखाता है जैसा कि उल्लेख किया गया URL सही है। इस उदाहरण में, हम किसी भी पैरामीटर को पारित नहीं कर रहे हैं, यह सिर्फ एक सरल अजाक्स अनुरोध है जो उल्लिखित URL को हिट करता है।

यदि आप डेवलपर टूल में क्रोम ब्राउज़र का उपयोग कर रहे हैं, तो नेटवर्क अनुभाग पर नेविगेट करें, आप अनुरोध भेज सकते हैं और जो प्रतिक्रिया हमें मिल रही है।

मापदंडों के बिना सरल अजाक्स अनुरोध - विफलता

<!DOCTYPE html>
<html>
   <head>
      <link href = "https://cdn.sencha.com/touch/sencha-touch-2.4.2/resources/css/sencha-touch.css" rel = "stylesheet" />
      <script type = "text/javascript" src = "https://cdn.sencha.com/touch/sencha-touch-2.4.2/sencha-touch-all.js"></script>
      <script type = "text/javascript">
         Ext.setup({
            requires: [
               'Ext.Panel',
               'Ext.Button',
               'Ext.form.Panel'
            ],
            onReady: function() {
               var request = {
                  url: 'https://www.tutorialspoint.com/sencha_touch/indexx.htm',
                  method: 'POST',
                  xhr2: true,
                  success: function(response) {
                     Ext.Msg.alert('Ajax call successful');
                  },
                  failure: function(response) {
                     Ext.Msg.alert('Ajax call failed');
                  }
               };
               Ext.Viewport.add({
                  xtype:"panel",
                  layout:"vbox",
                  fullscreen:true,
                  items: [
                     {
                        xtype:"button",
                        text: "Ajax",
                        ui: 'confirm',
                        handler: function(){
                           Ext.Ajax.request(request);
                        }
                     }
                  ]
               });
            }
         });
      </script>
   </head>
   <body>
   </body>
</html>

यह निम्नलिखित परिणाम का उत्पादन करेगा -

उपरोक्त उदाहरण में, यह दिखाने के लिए कि अजाक्स विफलता कैसे काम करती है, हमने गलत URL का उल्लेख किया है। इस और पिछले उदाहरण की तुलना करें, आपको अंतर मिलेगा।

अजाक्स अनुरोध में पैरामीटर भेजना

<!DOCTYPE html>
<html>
   <head>
      <link href = "https://cdn.sencha.com/touch/sencha-touch-2.4.2/resources/css/sencha-touch.css" rel = "stylesheet" />
      <script type = "text/javascript" src = "https://cdn.sencha.com/touch/sencha-touch-2.4.2/sencha-touch-all.js"></script>
      <script type = "text/javascript">
         Ext.setup({
            requires: [
               'Ext.Panel',
               'Ext.Button',
               'Ext.form.Panel'
            ],

            onReady: function() {
               var formData = new FormData();
               formData.append("firstName", "Hi");
               formData.append("lastName", "Reader");

               // Request will be sent as part of the payload instead of standard post data
               var request = {
                  url: 'https://www.tutorialspoint.com/sencha_touch/sencha_json.php',
                  method: 'POST',
                  xhr2: true,
                  data: formData,
                  success: function(response) {
                     var out = Ext.getCmp("output");
                     response = Ext.JSON.decode(response.responseText, true);
                     Ext.Msg.alert(response.message);
                  },
                  failure: function(response) {
                     var out = Ext.getCmp("output");
                     Ext.Msg.alert('Ajax failed!');
                  }
               };

               Ext.Viewport.add({
                  xtype:"panel",
                  layout:"vbox",
                  fullscreen:true,
                  items: [
                     {
                        xtype:"button",
                        text: "Ajax",
                        ui: 'confirm',
                        handler: function(){
                           Ext.Ajax.request(request);
                        }
                     }
                  ]
               });
            }
         });      
      </script>
   </head>
   <body>
   </body>
</html>

यह निम्नलिखित परिणाम का उत्पादन करेगा -

इस उदाहरण में, हम अजाक्स कॉल की डेटा संपत्ति का उपयोग करके अजाक्स के साथ पैरामीटर पारित कर रहे हैं।

Ajax का उपयोग करके फ़ाइलें अपलोड करना

<!DOCTYPE html>
<html>
   <head>
      <link href = "https://cdn.sencha.com/touch/sencha-touch-2.4.2/resources/css/sencha-touch.css" rel = "stylesheet" />
      <script type = "text/javascript" src = "https://cdn.sencha.com/touch/sencha-touch-2.4.2/sencha-touch-all.js"></script>
      <script type = "text/javascript">
         Ext.setup({
            requires: [
               'Ext.Panel',
               'Ext.MessageBox',
               'Ext.Button',
               'Ext.ProgressIndicator',
               'Ext.form.Panel',
               'Ext.field.FileInput'
            ],

            onReady: function() {
               var progressIndicator = Ext.create("Ext.ProgressIndicator", {
                  loadingText: "Uploading: {percent}%"
               });

               var request = {
                  url: 'https://www.tutorialspoint.com/sencha_touch/sencha_json.php',
                  method: 'POST',
                  xhr2: true,
                  progress:progressIndicator,
                  success: function(response) {
                     Ext.Msg.alert('File uploaded successfully.');
                  },
                  failure: function(response) {
                     Ext.Msg.alert('File upload failed.');
                  }
               };

               Ext.Viewport.add(progressIndicator);
               Ext.Viewport.add({
                  xtype:"panel",
                  layout:"vbox",
                  fullscreen:true,
                  items: [
                     {
                        xtype:"fileinput",
                        accept:"image/jpeg"
                     },
                     {
                        xtype:"button",
                        text: "Upload",
                        ui: 'confirm',
                        handler: function(){
                           var input = Ext.Viewport.down("fileinput").input;
                           var files = input.dom.files;
                           if (files.length) {
                              request.binaryData = files[0];
                              Ext.Ajax.request(request);
                           }else {
                              Ext.Msg.alert("Please Select a JPG");
                           }
                        }
                     }
                  ]
               });
            }
         });
      </script>
   </head>
   <body>
   </body>
</html>

यह निम्नलिखित परिणाम का उत्पादन करेगा -

यह उदाहरण दिखाता है कि ajax कॉल का उपयोग करके डेटा कैसे अपलोड किया जाए। इस उदाहरण में, हम फ़ाइल को अपलोड करते समय प्रगति दिखाने के लिए प्रगति बार संकेतक का उपयोग कर रहे हैं।