Михаиллл
July 6, 2019, 12:15 p.m.

Как сделать цикл for в QML

Добрый день.
Как сделать цикл for в QML?
Вариант записи с++ не работает.
Так тоже не работает

for ( i= 10 in 20)
3

Do you like it? Share on social networks!

9
Андрей Янкович
  • July 6, 2019, 12:52 p.m.

Если хочешь писать на qml учи javascript так как qml базируется на нем.
цикл for

const array = [1,2,3]
for (let i = 0; i < array.length; ++i) {
    console.log(array[i]);
}

цикл foreach

const array = [1,2,3]

array.forEach(function(obj) {
    console.log(obj);
});
    Андрей Янкович
    • July 6, 2019, 12:54 p.m.
    • The answer was marked as a solution.

    для qt постарше 5.12. (например 5.9)
    используй var в место let и const

      Михаиллл
      • July 6, 2019, 1:09 p.m.
      • (edited)

      Сделал так, но не работает:

      for (let i= 10; i < 20; i++)
      

      Говорит:
      qrc:/main.qml:12 Unexpected token `for'

      qrc:/main.qml:12 Unexpected token `let'

      qrc:/main.qml:12 Expected token `,'

        Evgenii Legotckoi
        • July 6, 2019, 3:17 p.m.
        • (edited)

        Покажите код main файла qml. Циклы в QML тоже нельзя пихать куда попало.

          Михаиллл
          • July 6, 2019, 3:20 p.m.

          Вот код

          import QtQuick 2.12
          import QtQuick.Window 2.12
          import QtLocation 5.12
          import QtPositioning 5.12
          
          Window {
              visible: true
                  width: 480
                  height: 720
                  title: qsTr("Map OSM")
          
                  for (var i = 0; i < 9; i++)  {
                      console.log(i)
                      i++
                  }
          
                  /* С помощью объекта Connections
                    * Устанавливаем соединение с классом ядра приложения
                    * */
                   Connections
                   {
                       target: houseNumber // Указываем целевое соединение
                       /* Объявляем и реализуем функцию, как параметр
                        * объекта и с имененем похожим на название сигнала
                        * Разница в том, что добавляем в начале on и далее пишем
                        * с заглавной буквы
                        * */
                      /* onSendToQml: {
                           labelCount.text = count // Устанавливаем счётчик в текстовый лейбл
                       }*/
                   }
          
                  Loader
                  {
                      id: loader
                      anchors.fill: parent
                      //source: "map.qml"
                  }
          }
          
            Evgenii Legotckoi
            • July 6, 2019, 3:27 p.m.

            Туда нельзя цикл вставлять. Циклы и любую подобную логику можно вставлять только в функции в QML, или в обработчики сигналов, что тоже самое, что функции.

            То есть ваш код не заработает в принципе.

            import QtQuick 2.12
            import QtQuick.Window 2.12
            import QtLocation 5.12
            import QtPositioning 5.12
            
            Window {
                visible: true
                    width: 480
                    height: 720
                    title: qsTr("Map OSM")
            
                    /* С помощью объекта Connections
                      * Устанавливаем соединение с классом ядра приложения
                      * */
                     Connections
                     {
                         target: houseNumber // Указываем целевое соединение
                         /* Объявляем и реализуем функцию, как параметр
                          * объекта и с имененем похожим на название сигнала
                          * Разница в том, что добавляем в начале on и далее пишем
                          * с заглавной буквы
                          * */
                        /* onSendToQml: {
                             labelCount.text = count // Устанавливаем счётчик в текстовый лейбл
                         }*/
                     }
            
                    Loader
                    {
                        id: loader
                        anchors.fill: parent
                        //source: "map.qml"
                    }
            
                    Component.onCompleted: {
                        for (var i = 0; i < 9; i++)  {
                            console.log(i)
                            i++
                        }
                    }
            }
            

            Так заработает

              Михаиллл
              • July 6, 2019, 3:35 p.m.

              Спасибо, Заработало. Но почему так?

                Evgenii Legotckoi
                • July 6, 2019, 3:43 p.m.

                Потому, что QML имеет такие правила написания код. У него есть структура - это по сути расширенный JSON, документ. Поэтому он собственно и хорошо совместим с JavaScript, а также является интерпретируемым языком. Можно написать проект чисто на QML и запустить его в интерпретаторе, без сборки проекта.

                Структура QML такова, что достаточно вольным образом можно объявлять объекты, свойства и функции.

                Вот например корректный код на QML

                import QtQuick 2.12
                import QtQuick.Window 2.12
                import QtLocation 5.12
                import QtPositioning 5.12
                
                Window {
                    visible: true
                        width: 480
                        height: 720
                        title: qsTr("Map OSM")
                
                         Connections
                         {
                             target: houseNumber // Указываем целевое соединение
                         }
                
                        Loader
                        {
                            id: loader
                            anchors.fill: parent
                        }
                
                        Component.onCompleted: {
                            for (var i = 0; i < 9; i++)  {
                                console.log(i)
                                i++
                            }
                        }
                
                        function showI() {
                            for (var i = 0; i < 9; i++)  {
                                console.log(i)
                                i++
                            }
                        }
                }
                

                Здесь объявлены объекты

                • Window
                • Connections
                • Loader

                Свойства

                • width:
                • height:
                • title:

                Функции

                • function showI()

                Всё это представляет древовидную структуру и укладывается в декларативный стиль программирования.

                А ваш цикл - это уже из императивного программирования. И это может быть написано только внутри функций в qml файлах. То есть либо в обработчиках, либо в теле функций, который были объявлены, как например showI функция.

                  Михаиллл
                  • July 6, 2019, 3:47 p.m.

                  Ясно, спасибо за объяснение.

                    Comments

                    Only authorized users can post comments.
                    Please, Log in or Sign up
                    • Last comments
                    • AK
                      April 24, 2025, 12:04 p.m.
                      UPD: Переписал логику воспроизведения через стороннюю библиотеку BASS. Там выбрать можно
                    • Evgenii Legotckoi
                      April 16, 2025, 5:08 p.m.
                      Благодарю за отзыв. И вам желаю всяческих успехов!
                    • IscanderChe
                      April 12, 2025, 5:12 p.m.
                      Добрый день. Спасибо Вам за этот проект и отдельно за ответы на форуме, которые мне очень помогли в некоммерческих пет-проектах. Профессиональным программистом я так и не стал, но узнал мно…
                    • AK
                      April 1, 2025, 11:41 a.m.
                      Добрый день. В данный момент работаю над проектом, где необходимо выводить звук из программы в определенное аудиоустройство (колонки, наушники, виртуальный кабель и т.д). Пишу на Qt5.12.12 поско…
                    • Evgenii Legotckoi
                      March 9, 2025, 9:02 p.m.
                      К сожалению, я этого подсказать не могу, поскольку у меня нет необходимости в обходе блокировок и т.д. Поэтому я и не задавался решением этой проблемы. Ну выглядит так, что вам действитель…