qt qml ajax 獲取 json 天氣數據示例

依賴ajax.js類庫,如下代碼很簡單的實現了獲取天氣json數據並展現的任務html

 

【TestAjax.qml】ajax

 1 import QtQuick 2.0
 2 import "ajax.js" as Ajax
 3 
 4 
 5 /**
 6 測試用ajax 獲取 json 數據
 7 更復雜的ajax調用請查看 qml/network/ 相關示例
 8 */
 9 Grid{
10     width: 600
11     height: 400
12     spacing: 10
13     columns: 2
14 
15     Text {text: 'city:'}
16     Text {id:city; text:' '}
17 
18     Text {text: 'date:'}
19     Text {id:date; text:' '}
20 
21     Text {text: 'temp:'}
22     Text {id:temp1; text:' '}
23 
24     Component.onCompleted: {
25         // 中國天氣網實況天氣接口(可用)
26         Ajax.get("http://www.weather.com.cn/data/sk/101010100.html",
27             function(result, json){
28                 city.text = json.weatherinfo.city;
29                 date.text = json.weatherinfo.time;
30                 temp1.text = json.weatherinfo.temp;
31             }
32         );
33 
34         /*
35         // 中華萬年曆的當天及預告天氣接口(可用)
36         Ajax.get("http://wthrcdn.etouch.cn/weather_mini?city=%E5%8C%97%E4%BA%AC",
37             function(result, json){
38                 city.text = json.data.city;
39                 date.text = json.data.forecast[0].date;
40                 temp1.text = json.data.wendu;
41             }
42         );
43         */
44 
45         /*
46         // 中國天氣網當天及預告天氣接口(接口掛了)
47         Ajax.get("http://m.weather.com.cn/data/101010100.html",
48             function(result, json){
49                 city.text = json.weatherinfo.city;
50                 date.text = json.weatherinfo.date_y;
51                 temp1.text = json.weatherinfo.temp1;
52             }
53         );
54         */
55     }
56 }

 

 

【ajax.js】json

 1 // GET
 2 function get(url, success, failure)
 3 {
 4     var xhr = new XMLHttpRequest;
 5     xhr.open("GET", url);
 6     xhr.onreadystatechange = function() {
 7         handleResponse(xhr, success, failure);
 8     }
 9     xhr.send();
10 }
11 
12 // POST
13 function post(url, arg, success, failure)
14 {
15     var xhr = new XMLHttpRequest;
16     xhr.open("POST", url);
17     xhr.setRequestHeader("Content-Length", arg.length);
18     xhr.setRequestHeader("Content-Type", "application/x-www-form-urlencoded;");  //用POST的時候必定要有這句
19     xhr.onreadystatechange = function() {
20         handleResponse(xhr, success, failure);
21     }
22     xhr.send(arg);
23 }
24 
25 
26 
27 // 處理返回值
28 function handleResponse(xhr, success, failure){
29     if (xhr.readyState == XMLHttpRequest.DONE) {
30         if (xhr.status ==  200){
31             if (success != null && success != undefined)
32             {
33                 var result = xhr.responseText;
34                 try{
35                     success(result, JSON.parse(result));
36                 }catch(e){
37                     success(result, {});
38                 }
39             }
40         }
41         else{
42             if (failure != null && failure != undefined)
43                 failure(xhr.responseText, xhr.status);
44         }
45     }
46 }

 

代碼下載app

相關文章
相關標籤/搜索