J'essaie de comprendre comment créer une propriété ListElement à plusieurs lignes.
J'ai un ListModel avec ListElements comme ceci :
ListElement { key: "key"; value: 1; description: "Very long, full paragraph description that extends way off the screen which I would like to wrap in code nicely." }
Je peux renvoyer des lignes à la ligne en entrant simplement un caractère de nouvelle ligne, mais les lignes suivantes ne s'alignent pas avec le bloc de texte.
description: "Very long, full paragraph description that extends way off the screen which I would like to wrap in code nicely."
Lorsque j'essaie de tabuler sur le texte pour l'aligner, cela entraîne beaucoup d'espaces lorsque la description s'imprime à l'écran (ce qui est logique, mais ce n'est évidemment pas ce que je veux).
description: "Very long, full paragraph description that extends way off the screen which I would like to wrap nicely in code."
Very long, full paragraph description that extends way off the screen which I would like to wrap in code nicely.
J'ai essayé de me connecter via "+" mais cela produit l'erreur : ListElement:无法使用脚本获取属性值
.
J'ai essayé d'utiliser des barres obliques inverses comme dans le fichier .pro mais cela n'a pas fonctionné non plus.
Les nouvelles lignes fonctionnent, mais elles n'ont pas d'importance car elles ne résolvent pas le problème des espaces.
Very long, full paragraph description that extends way off the screen which I would like to wrap in code nicely.
Si quelqu'un a des idées, je lui serais très reconnaissant.
Tout d’abord, vous pouvez envisager d’utiliser la notation Javascript backtick pour déclarer des chaînes multilignes.
En plus de cela, vous pouvez trouver
ListElement
声明具有限制性,不支持 Javascript 表达式,例如Date.now()
Dans ces cas, vous pouvez envisager d'utiliser du code impératif. Si vous souhaitez un aspect quelque peu déclaratif, vous pouvez déclarer un tableau d'objets Javascript et parcourir celui-ci.Lors du rendu, vous pouvez également envisager d'utiliser
wrapMode: Text.Wrap
pour appliquer un retour à la ligne supplémentaire afin de formater le texte.Vous pouvezl'essayer en ligne !
Je n'ai pas de solution directe pour l'implémentation que vous utilisez qui crée directement ListElements. Mais la méthode .append() de ListModel prend un objet JS comme paramètre. Ceux-ci prennent en charge les chaînes multilignes. Ainsi, au lieu de créer des ListElements comme ceci, vous pouvez les ajouter lorsque le composant est terminé comme ceci :