QML学习笔记(五十三)QML与C++交互:数据转换——序列类型与 JavaScript 数组的转换

前言

本节介绍一下序列类型和数组之间的转换,简单来说就是C++的QVetor和qml中的数组之间的转换。

一、代码示例

只展示核心代码:

cpp 复制代码
class CppClass : public QObject
{
    Q_OBJECT

public:
    explicit CppClass(QObject *parent = nullptr);

    Q_INVOKABLE void qmlArrayToCpp(QVector<QString> vector);
    Q_INVOKABLE QVector<QString> retrieveStrings();
private:
    QVector<QString> mVector;
};
cpp 复制代码
#include "cppclass.h"
#include <QDebug>

CppClass::CppClass(QObject *parent) : QObject(parent)
{
    mVector.append("One");
    mVector.append("Two");
    mVector.append("Three");
    mVector.append("Four");
}

void CppClass::qmlArrayToCpp(QVector<QString> vector)
{
    foreach (QString string, vector){
        qDebug()<< string;
    }
}

QVector<QString> CppClass::retrieveStrings()
{
    return mVector;
}
cpp 复制代码
import QtQuick 2.14
import QtQuick.Window 2.14
import QtQuick.Controls 2.12
import com.mycompany 1.0

Window {
	// ...
    CppClass{
        id: cppClassId
    }

    Button{
        id: buttonId
    }
    Button{
        id:button1Id
        text:"Send to C++"
        x: buttonId.x + buttonId.width
        onClicked:function(){
            var arr = ['Apple', 'Banana','Avocado','Pear','Orange'];
            cppClassId.qmlArrayToCpp(arr)
        }
    }
    Button{
        id: button2Id
        text:"Read form C++"
        anchors.left: button1Id.right
        onClicked:function(){
            var arr = cppClassId.retrieveStrings()
            print("The length of the array is:"+ arr.length)
            arr.forEach(function(element){
                console.log(element)
            })
        }
    }
}

打印:

可以看到,其实并不需要什么特殊处理的转换,qt会自动匹配转换的。

二、总结

这种数组和序列的数据是很常见的变量,从C++发送到qml进行前端展示,或者从qml端搜集后要发送到C++端进行存储和管理都是很常见的需求。

相关推荐
一匹电信狗2 小时前
【LeetCode_547_990】并查集的应用——省份数量 + 等式方程的可满足性
c++·算法·leetcode·职场和发展·stl
Queenie_Charlie3 小时前
小陶的疑惑2
数据结构·c++·树状数组
三水不滴3 小时前
Redis 过期删除与内存淘汰机制
数据库·经验分享·redis·笔记·后端·缓存
wdfk_prog4 小时前
[Linux]学习笔记系列 -- [drivers][i2c]i2c-dev
linux·笔记·学习
土拨鼠烧电路4 小时前
笔记03:业务语言速成:“人、货、场”模型与IT系统全景图
笔记
Queenie_Charlie4 小时前
小陶与杠铃片
数据结构·c++·树状数组
CoderCodingNo4 小时前
【GESP】C++四级/五级练习题 luogu-P1223 排队接水
开发语言·c++·算法
2301_812731415 小时前
CSS3笔记
前端·笔记·css3
越努力越幸运5085 小时前
CSS3学习之网格布局grid
前端·学习·css3
sycmancia5 小时前
C++进阶01——示例
开发语言·c++