关于qml中组件属性赋值的问题

HalfbloodPri 2017-07-13 11:12:41
Rectangle {
id: root
property var rec0Color: "black"
property var rec1Color: "black"
property var recColor: new Array("white", "black")
Rectangle {
id: rec0
color: root.rec0Color
//color: root.recColor[0]
}
Rectangle {
id: rec1
color: root.rec1Color
//color:root.recColor[1]
}
}
在上面的代码中我如果改变root.rec0Color和root.rec1Color的值,rec0和rec1的颜色会直接发生改变,
但是如果按照注释掉的语句中的写法,然后改变数组recColor前两个变量的值,rec0和rec1的颜色却不会变,为什么?求解释
...全文
832 5 打赏 收藏 转发到动态 举报
写回复
用AI写文章
5 条回复
切换为时间正序
请发表友善的回复…
发表回复
hcq318 2018-10-23
  • 打赏
  • 举报
回复
3楼 zhengjiankang是正解,上面二位没有明白别人意思,不是不能正常显示颜色,是颜色不会动态改变。
zhengjiankang 2017-07-18
  • 打赏
  • 举报
回复
你可以选择写 recColor = new Array("red", "blue")
zhengjiankang 2017-07-18
  • 打赏
  • 举报
回复
前者直接绑定属性color,数据绑定会自动给你更新属性。 后者绑定的是数据内部的一个数据,变化的也是数组内部的数据,不会触发更新。
辉狼007 2017-07-16
  • 打赏
  • 举报
回复
高度和宽度都需要设置下吧? 下面的亲测是可以的。 Rectangle { id: root width:500 height:500 property var rec0Color: "black" property var rec1Color: "black" property var recColor: new Array("red", "black") Rectangle { id: rec0 width:100 height:100 // color: root.rec0Color color: root.recColor[0] } Rectangle { id: rec1 x:150 y:150 width:100 height:100 // color: root.rec1Color color:root.recColor[1] } }
画茧自缚 2017-07-15
  • 打赏
  • 举报
回复
我这里是可以正常显示的,可以贴出全部代码看下,你的rect是锚定其它部件内的吗,否则你问什么没有给他们长和宽。我的代码
import QtQuick 2.5
import QtQuick.Controls 1.4

ApplicationWindow {
visible: true
width: 640
height: 480
title: qsTr("Hello World")

Rectangle {
id: root
anchors.fill: parent
property var rec0Color: "black"
property var rec1Color: "black"
property var recColor: new Array("blue", "black")

Rectangle {
id: rec0
width: 100
height: 100
// color: root.rec0Color
color: root.recColor[0]
}
Rectangle {
id: rec1
x: 200
y: 200
height: 50
width: 50
// color: root.rec1Color
color:root.recColor[1]
}
}
}

16,202

社区成员

发帖
与我相关
我的任务
社区描述
Qt 是一个跨平台应用程序框架。通过使用 Qt,您可以一次性开发应用程序和用户界面,然后将其部署到多个桌面和嵌入式操作系统,而无需重复编写源代码。
社区管理员
  • Qt
  • 亭台六七座
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧