涉及到Http请求,第一反应可能是使用Qt的QNetworkRequest和QNetworkReply实现,然后QML再与其交互,但是这样过于麻烦了。其实QML自己已经具备了http网络请求访问的功能。而且使用起来很方便。
我们这里举一个访问天气接口,然后解析其数据的例子。
一,看下效果
二,代码
主要是利用XMLHttpRequest这个类,请求接口,然后将返回的数据解析成json对象(JSON.parse),之后就可以像js一样去拿json对象里的数据了,当然前提是接口返回得数据是json。
import QtQuick 2.15 import QtQuick.Window 2.15 import QtQuick.Controls 2.15 Window { width: 640 height: 480 visible: true title: qsTr("Hello World") //主要看这个函数 function request() { var xhr = new XMLHttpRequest(); xhr.onreadystatechange = function() { if (xhr.readyState === XMLHttpRequest.HEADERS_RECEIVED) { console.log('HEADERS_RECEIVED') } else if(xhr.readyState === XMLHttpRequest.DONE) { console.log('DONE') console.log(xhr.responseText.toString()) var object = JSON.parse(xhr.responseText.toString()); text.append(object["errcode"]) text.append(object["errmsg"]) } } xhr.open("GET", "http://v0.yiketianqi.com/free/v2030?city=&cityid=&adcode=130200000000&appid=&appsecret=&lng=&lat=&aqi=&hours="); xhr.send(); } Button{ anchors.centerIn: parent onClicked: { request() } } TextEdit { id: text height: 200 width: 300 anchors.bottom: parent.bottom anchors.horizontalCenter: parent.horizontalCenter } }