a
ayb25. Februar 2020 05:33

WebView

Задам, очень тупой вопрос, Как мне передать в url на webview, которая находится на другой странице, и затем я мог вернуться задать url, и подгрузить другую страницу. Условно говоря всего две qml - страница с webview, и первая с кнопкой и текстовым полем.

Рекомендуємо хостинг TIMEWEB
Рекомендуємо хостинг TIMEWEB
Stabiles Hosting des sozialen Netzwerks EVILEG. Wir empfehlen VDS-Hosting für Django-Projekte.

Magst du es? In sozialen Netzwerken teilen!

14
Evgenii Legotckoi
  • 25. Februar 2020 05:52
  • (bearbeitet)

Добрый день.

Самый простой однооконный вариант реализуется так

import QtQuick 2.12
import QtQuick.Window 2.12
import QtWebView 1.13
import QtQuick.Controls 2.13

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

    TextField {
        id: textEdit
        anchors.left: parent.left
        anchors.top: parent.top
        anchors.right: button.left
    }

    Button {
        id: button
        text: "Go"
        anchors.top: parent.top
        anchors.right: parent.right

        onClicked: {
            webView.url = textEdit.text
        }
    }

    WebView {
        id: webView
        anchors.left: parent.left
        anchors.top: textEdit.bottom
        anchors.right: parent.right
        anchors.bottom: parent.bottom
    }
}

Результат выглядит так

Конкретно в вашем случае, если у вас два qml файла, нужно смотреть код, возможно нужно будет прописать alias`ы на нужные объекты, чтобы всё увязать друг с другом.

    a
    • 25. Februar 2020 06:06
    • (bearbeitet)

    Спасибо, кажется понял, почему у меня не работало.

      a
      • 25. Februar 2020 07:16

      Вообщем когда все было на одной странице все работало, На двух нет(

        Evgenii Legotckoi
        • 25. Februar 2020 07:17

        я не экстрасенс. нужно смотреть ваш код

          a
          • 25. Februar 2020 07:17
          • (bearbeitet)
          id: expressPage
              allowedOrientations: Orientation.All
          
              function setUrl(str) {
                  webView.url = str
              }
          
              SilicaWebView {
                  id: webView
                  // PullDownMenu and PushUpMenu must be declared in SilicaFlickable, SilicaListView or SilicaGridView
                  PullDownMenu {
                      MenuItem {
                          text: qsTr("Вернуться на welcome")
                          onClicked: {
                              pageStack.clear()
                              pageStack.push(Qt.resolvedUrl("Welcome.qml"))
                          }
                      }
                      MenuItem {
                          text: qsTr("Выход")
                          onClicked: {
                              Qt.quit()
                          }
                      }
                  }
                  anchors.fill: parent
          
                  onLoadingChanged: {
                      console.log(webView.url)
                      webView.update()
                  }
          
                  quickScrollAnimating: true
          
                  experimental.preferences.webGLEnabled: true
                  experimental.preferences.notificationsEnabled: true
                  experimental.preferences.dnsPrefetchEnabled: true
                  experimental.preferences.javascriptEnabled: true
              }
          

          Примерно как выглядит webview, может я что-то не дописал

            a
            • 25. Februar 2020 07:23
            • (bearbeitet)
            // To enable PullDownMenu, place our content in a SilicaFlickable
                SilicaListView {
                    id: flickId
                    anchors.fill: parent
            
                    // PullDownMenu and PushUpMenu must be declared in SilicaFlickable, SilicaListView or SilicaGridView
                    PullDownMenu {
                        MenuItem {
                            text: qsTr("Выход")
                            onClicked: {
                                webApp.setAddress("")
                                Qt.quit()
                            }
                        }
                    }
            
                    Column {
                        width: parent.width
                        spacing: Theme.paddingLarge
                        Label {
                            id: emptyLabel
                            height: mainPage.height / 3
                            width: parent.width
                        }
            
                        TextField {
                            id: textField
                            width: parent.width
            
                            horizontalAlignment: Text.AlignHCenter
                            anchors.horizontalCenter: parent.horizontalCenter
                            anchors.horizontalCenterOffset: Theme.horizontalPageMargin
                            placeholderText: qsTr("www.google.com")
                            validator: RegExpValidator { regExp: /^(https?:\/\/)?([\da-z\.-]+)\.([a-z\.]{2,6})([\/\w \.-]*)*\/?$/ }
                            onTextChanged: {
                                console.log(textField.text)
                            }
                        }
                        Button {
                            id: btnId
                            anchors.horizontalCenter: parent.horizontalCenter
                            text: "Send url"
                            onClicked: {
                                webApp.setUrl(textField.text)
                                pageStack.push(Qt.resolvedUrl("WebView.qml"))
                            }
                        }
                        Label {
                            id: orId
                            color: Theme.highlightBackgroundColor
                            anchors.horizontalCenter: parent.horizontalCenter
                            text: "or"
                        }
                        Button {
                            id: btnSettings
                            text: "Settings"
                            anchors.horizontalCenter: parent.horizontalCenter
                            onClicked: {
                                var urlPath = "http://" + initWeb.getAddress()
                                webApp.setUrl(urlPath)
                                pageStack.push(Qt.resolvedUrl("WebView.qml"))
                            }
                        }
            

            Это первая страница

              a
              • 25. Februar 2020 07:24

              Функция getAddress, возвращает строку из qsettings, из плюсовой части.

                Evgenii Legotckoi
                • 25. Februar 2020 07:41
                • (bearbeitet)

                так у вас ещё не чистый QML а Sailfish framework... Но тут очевидно ошибки логические и отсутствие правильного доступа к id. Дело не в самом фреймворке.

                Как называются эти две страницы и как они соотносятся друг с другом. Вторая страница вложена в первую? Первая называется WebView.qml? Что такое pageStack и откуда вы его взяли? Я не вижу в коде id: pageStack, да и обращение к id webApp во второй странице в этом коде является некорректным, поскольку доступа к нему нет.

                P/S/ в дальнейшем используйте специальный диалог для вставки программного кода на сайте. В toolbar редактора находится. Иначе некорректно делается форматирование.

                  a
                  • 25. Februar 2020 07:44

                  Извините описался, уже поправил, страницы Welcome и WebApp.

                    Evgenii Legotckoi
                    • 25. Februar 2020 07:46

                    тем не менее я не вижу pageStack, если это классический StackView, то сначала нужно загрузить в него WebView.qml, а потом пытаться загружать url

                    Как-то так

                    pageStack.push(Qt.resolvedUrl("WebView.qml"))
                    var urlPath = "http://" + initWeb.getAddress()
                    pageStack.currentItem.setUrl(urlPath)
                    
                    
                      a
                      • 25. Februar 2020 07:59

                      Спасибо, исправил. Буду разбираться дальше, он что и сам обновляться не хочет

                        a
                        • 25. Februar 2020 08:00

                          Evgenii Legotckoi
                          • 25. Februar 2020 08:04
                          • (bearbeitet)

                          Вот знаете, это вот треш

                          onUrlChanged: {
                              console.log(webView.url)
                              webView.url = "http://www.google.com/"
                          }
                          

                          Представляете, как это работает?

                          Вы устанавливаете url, срабатывает onUrlChanged, выводит в консоль, вы снова устанавливаете url, срабатывает onUrlChanged, выводит в консоль, вы снова устанавливаете url, срабатывает onUrlChanged, выводит в консоль, вы снова устанавливаете url, срабатывает onUrlChanged, выводит в консоль, вы снова устанавливаете url, срабатывает onUrlChanged, выводит в консоль, вы снова устанавливаете url, срабатывает onUrlChanged, выводит в консоль, вы снова устанавливаете url, срабатывает onUrlChanged, выводит в консоль, вы снова устанавливаете url, срабатывает onUrlChanged, выводит в консоль, вы снова устанавливаете url, срабатывает onUrlChanged, выводит в консоль, вы снова устанавливаете url, срабатывает onUrlChanged, выводит в консоль, вы снова устанавливаете url, срабатывает onUrlChanged, выводит в консоль, вы снова устанавливаете url, срабатывает onUrlChanged, выводит в консоль, вы снова устанавливаете url, срабатывает onUrlChanged, выводит в консоль, вы снова устанавливаете url, срабатывает onUrlChanged, выводит в консоль, вы снова устанавливаете url, срабатывает onUrlChanged, выводит в консоль, вы снова устанавливаете url, срабатывает onUrlChanged, выводит в консоль, вы снова устанавливаете url, срабатывает onUrlChanged, выводит в консоль, вы снова устанавливаете url, срабатывает onUrlChanged, выводит в консоль, вы снова устанавливаете url, срабатывает onUrlChanged, выводит в консоль, вы снова устанавливаете url, срабатывает onUrlChanged, выводит в консоль, вы снова устанавливаете url, срабатывает onUrlChanged, выводит в консоль, вы снова устанавливаете url, срабатывает onUrlChanged, выводит в консоль, вы снова устанавливаете url, срабатывает onUrlChanged, выводит в консоль, вы снова устанавливаете url

                          Понятно?

                            a
                            • 25. Februar 2020 08:06

                            Да

                              Kommentare

                              Nur autorisierte Benutzer können Kommentare posten.
                              Bitte Anmelden oder Registrieren
                              Letzte Kommentare
                              ИМ
                              Игорь Максимов5. Oktober 2024 07:51
                              Django – Lektion 064. So schreiben Sie eine Python-Markdown-Erweiterung Приветствую Евгений! У меня вопрос. Можно ли вставлять свои классы в разметку редактора markdown? Допустим имея стандартную разметку: <ul> <li></li> <li></l…
                              d
                              dblas55. Juli 2024 11:02
                              QML - Lektion 016. SQLite-Datenbank und das Arbeiten damit in QML Qt Здравствуйте, возникает такая проблема (я новичок): ApplicationWindow неизвестный элемент. (М300) для TextField и Button аналогично. Могу предположить, что из-за более новой верси…
                              k
                              kmssr8. Februar 2024 18:43
                              Qt Linux - Lektion 001. Autorun Qt-Anwendung unter Linux как сделать автозапуск для флэтпака, который не даёт создавать файлы в ~/.config - вот это вопрос ))
                              Qt WinAPI - Lektion 007. Arbeiten mit ICMP-Ping in Qt Без строки #include <QRegularExpressionValidator> в заголовочном файле не работает валидатор.
                              EVA
                              EVA25. Dezember 2023 10:30
                              Boost - statisches Verknüpfen im CMake-Projekt unter Windows Ошибка LNK1104 часто возникает, когда компоновщик не может найти или открыть файл библиотеки. В вашем случае, это файл libboost_locale-vc142-mt-gd-x64-1_74.lib из библиотеки Boost для C+…
                              Jetzt im Forum diskutieren
                              J
                              JacobFib17. Oktober 2024 03:27
                              добавить qlineseries в функции Пользователь может получить любые разъяснения по интересующим вопросам, касающимся обработки его персональных данных, обратившись к Оператору с помощью электронной почты https://topdecorpro.ru…
                              JW
                              Jhon Wick1. Oktober 2024 15:52
                              Indian Food Restaurant In Columbus OH| Layla’s Kitchen Indian Restaurant If you're looking for a truly authentic https://www.laylaskitchenrestaurantohio.com/ , Layla’s Kitchen Indian Restaurant is your go-to destination. Located at 6152 Cleveland Ave, Colu…
                              КГ
                              Кирилл Гусарев27. September 2024 09:09
                              Не запускается программа на Qt: точка входа в процедуру не найдена в библиотеке DLL Написал программу на C++ Qt в Qt Creator, сбилдил Release с помощью MinGW 64-bit, бинарнику напихал dll-ки с помощью windeployqt.exe. При попытке запуска моей сбилженной программы выдаёт три оши…
                              F
                              Fynjy22. Juli 2024 04:15
                              при создании qml проекта Kits есть но недоступны для выбора Поставил Qt Creator 11.0.2. Qt 6.4.3 При создании проекта Qml не могу выбрать Kits, они все недоступны, хотя настроены и при создании обычного Qt Widget приложения их можно выбрать. В чем может …

                              Folgen Sie uns in sozialen Netzwerken