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++端进行存储和管理都是很常见的需求。

相关推荐
不爱吃糖的程序媛10 小时前
OpenHarmony 通用C/C++三方库 标准化鸿蒙化适配
c语言·c++·harmonyos
fqbqrr10 小时前
2601C++,导出控制
c++
陌路2010 小时前
日志系统7--异步日志的实现
c++
程序员Jared11 小时前
C++11—this_thread
c++·this_thread
万事可爱^11 小时前
LangChain v1.0学习笔记(4)—— 核心组件Models
人工智能·笔记·学习·langchain·大模型
mjhcsp11 小时前
C++ Manacher 算法:原理、实现与应用全解析
java·c++·算法·manacher 算法
Z1Jxxx11 小时前
0和1的个数
数据结构·c++·算法
卡布叻_星星11 小时前
笔记之光盘刻录
笔记
寄思~11 小时前
Excel 数据匹配工具 -笔记
笔记·python·学习·excel
朔北之忘 Clancy11 小时前
2020 年 6 月青少年软编等考 C 语言二级真题解析
c语言·开发语言·c++·学习·青少年编程·题解·尺取法