Style de codage Qt et QML
Qt/c++
Nom de signal et de fente
Les signaux et les fentes doivent utiliser camelCase. Un signal doit utiliser le simple passé passé ou le participle passé d’un verbe, probablement préfixé par un sujet court.
// correct
signal:
void shutdownScheduled();
void navigationRequested();
...
slot:
void onShutdownScheduled();
void onNavigationRequested();
// incorrect
signal:
void shutdown();
void navigateToHomeView();
...
slot:
void onShutdown();
void slotNavigateToHomeView();
L’équipement
Formattement du code
La version Qt 5.15.0 du format qml a quelques problèmes concernant les sections de commentaires et ne fait actuellement pas de discrimination contre les colonnes max, nous continuerons donc à formater en utilisant ces lignes directrices pour l’instant. Voici un composant échantillon complet, adapté de https://doc.qt.io/qt-5/qml-codingconventions.html, qui tente d’illustrer le composant idéalement formaté.
/*
* authored by/copyright ...
*/
// Id always on the first line, and always present and called root
// for root component. Only present if referenced for children.
// Multi-line comments use '//'.
// There should always be a brief description of a component.
// Multi-line comments start with a capital letter and end with
// a period.
Rectangle {
id: root
// property declarations
property bool thumbnail: false
property alias image: photoImage.source
// signal declarations
signal clicked
// javascript functions
function doSomething(x) {
return x + photoImage.width
}
// object properties
color: "gray"
// try to group related properties together
x: 20
y: 20
height: 150
// large bindings
width: {
// Always space all operators, and add a single space
// before opening brackets.
if (photoImage.width > 200) {
photoImage.width
} else {
height
}
}
// child objects (contentItem, defaults, etc. first)
Rectangle {
id: border
anchors.centerIn: parent
color: "white"
Image {
id: photoImage
anchors.centerIn: parent
}
}
Text {
anchors.centerIn: photoImage
// Use the ellipsis character (…) for manual ellision within
// UI text and don't translate untranslatables.
text: qsTr("an emoji: %1 and a number: %2 …").arg("💡").arg(42)
}
// states
states: State {
name: "selected"
PropertyChanges {
target: border
color: "red"
}
}
// transitions
transitions: Transition {
from: ""
to: "selected"
ColorAnimation {
target: border
duration: 200
}
}
}