QML中调用HTTP请求

涉及到Http请求,第一反应可能是使用Qt的QNetworkRequest和QNetworkReply实现,然后QML再与其交互,但是这样过于麻烦了。其实QML自己已经具备了http网络请求访问的功能。而且使用起来很方便。

我们这里举一个访问天气接口,然后解析其数据的例子。

一,看下效果

QML中调用HTTP请求 – Qt hello

二,代码

主要是利用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
    }
}

编辑

相关推荐

  1. QML调用HTTP请求

    2024-04-26 08:12:05       106 阅读
  2. qtqml调用cpp的逻辑

    2024-04-26 08:12:05       27 阅读
  3. oracle服务器存储过程调用http

    2024-04-26 08:12:05       28 阅读
  4. 如何在Go发起HTTP请求

    2024-04-26 08:12:05       79 阅读
  5. GolangHTTP请求凝聚器

    2024-04-26 08:12:05       49 阅读
  6. 网站建设HTTP 请求方法

    2024-04-26 08:12:05       45 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-04-26 08:12:05       94 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-04-26 08:12:05       101 阅读
  3. 在Django里面运行非项目文件

    2024-04-26 08:12:05       82 阅读
  4. Python语言-面向对象

    2024-04-26 08:12:05       91 阅读

热门阅读

  1. conda环境查看当前可下载的Django版本

    2024-04-26 08:12:05       38 阅读
  2. K8S Service 常见问题

    2024-04-26 08:12:05       30 阅读
  3. 2-token生成

    2024-04-26 08:12:05       35 阅读
  4. 每天学习一个Linux命令之awk

    2024-04-26 08:12:05       31 阅读
  5. mysql 意向锁

    2024-04-26 08:12:05       37 阅读
  6. 46、有向图的拓扑序列

    2024-04-26 08:12:05       28 阅读
  7. 每天学习一个Linux命令之bzip2

    2024-04-26 08:12:05       30 阅读
  8. Elasticsearch 详细介绍和经典应用

    2024-04-26 08:12:05       34 阅读
  9. VSCode 常用配置

    2024-04-26 08:12:05       28 阅读
  10. 使用rust学习基本算法(三)

    2024-04-26 08:12:05       28 阅读
  11. js中Symbol值的强制类型转换

    2024-04-26 08:12:05       39 阅读