QMLコーディング規約
このドキュメントでは、QML のコーディング規約について説明します。
QML オブジェクトの宣言
QML オブジェクトの属性は、文書やサンプルを通して、常に以下の順序で記述されています:
- id
- プロパティ宣言
- シグナル宣言
- JavaScript の関数
- オブジェクトのプロパティ
- 子オブジェクト
読みやすくするために、これらの異なる部分を空行で区切ります。
例えば、仮想的な写真のQMLオブジェクトは次のようになります:
Rectangle { id: photo // id on the first line makes it easy to find an object property bool thumbnail: false // property declarations property alias image: photoImage.source signal clicked // signal declarations function doSomething(x) // javascript functions { return x + photoImage.width; } color: "gray" // object properties x: 20 // try to group related properties together y: 20 height: 150 width: { // large bindings if (photoImage.width > 200) { photoImage.width; } else { 200; } } states: [ State { name: "selected" PropertyChanges { target: border; color: "red" } } ] transitions: [ Transition { from: "" to: "selected" ColorAnimation { target: border; duration: 200 } } ] Rectangle { // child objects id: border anchors.centerIn: parent color: "white" Image { id: photoImage anchors.centerIn: parent } } }
グループ化されたプロパティ
複数のプロパティをグループ化して使用する場合、読みやすさが向上するのであれば、ドット記法の代わりにグループ記法を使用することを検討してください。
例えば
Rectangle { anchors.left: parent.left; anchors.top: parent.top; anchors.right: parent.right; anchors.leftMargin: 20 } Text { text: "hello" font.bold: true; font.italic: true; font.pixelSize: 20; font.capitalization: Font.AllUppercase }
はこのように書くことができます:
Rectangle { anchors { left: parent.left; top: parent.top; right: parent.right; leftMargin: 20 } } Text { text: "hello" font { bold: true; italic: true; pixelSize: 20; capitalization: Font.AllUppercase } }
非限定アクセス
可読性とパフォーマンスを向上させるためには、常に親コンポーネントのプロパティをidで明示的に参照すること:
必須プロパティ
コンポーネントの外部で定義されたデータが必要な場合は、Required Propertiesを使用して明示的に指定します。Requiredプロパティを設定しないと、コンポーネントの作成に失敗します。これらは、非限定的なルックアップよりもパフォーマンスが高く、ユーザーとツールの両方が外部プロパティの型について推論できるため、好ましい。さらに、これらのルックアップは、コンポーネントが作成される環境について、コンポーネントが行わなければならない仮定を取り除きます。
シグナルハンドラ
シグナルハンドラでパラメータを処理する場合は、明示的に名前を付ける関数を使用します:
MouseArea { onClicked: event => { console.log(`${event.x},${event.y}`); } }
JavaScriptコード
スクリプトが単一の式の場合は、インラインで記述することを推奨します:
Rectangle { color: "blue"; width: parent.width / 3 }
スクリプトが数行しかない場合は、通常ブロックを使用します:
Rectangle { color: "blue" width: { var w = parent.width / 3; console.debug(w); return w; } }
スクリプトが2、3行以上の場合や、異なるオブジェクトで使用できる場合は、このように関数を作成し、それを呼び出すことをお勧めします:
function calculateWidth(object : Item) : double { var w = object.width / 3; // ... // more javascript code // ... console.debug(w); return w; } Rectangle { color: "blue"; width: calculateWidth(parent) }
また、アプリケーションの推論やリファクタリングをより簡単に行うために、関数に型アノテーションを追加することをお勧めします。
長いスクリプトの場合は、関数を独自のJavaScriptファイルに入れて、次のようにインポートします:
import "myscript.js" as Script Rectangle { color: "blue"; width: Script.calculateWidth(parent) }
コードが1行より長く、ブロック内にある場合は、セミコロンを使って各ステートメントの終わりを示します:
MouseArea { anchors.fill: parent onClicked: event => { var scenePos = mapToItem(null, event.x, event.y); console.log("MouseArea was clicked at scene pos " + scenePos); } }
関連情報
本ドキュメントに含まれる文書の著作権は、それぞれの所有者に帰属します。 本書で提供されるドキュメントは、Free Software Foundation が発行したGNU Free Documentation License version 1.3に基づいてライセンスされています。 Qtおよびそれぞれのロゴは、フィンランドおよびその他の国におけるThe Qt Company Ltd.の 商標です。その他すべての商標は、それぞれの所有者に帰属します。