a
Feb. 25, 2020, 5:33 a.m.

WebView

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

We recommend hosting TIMEWEB
We recommend hosting TIMEWEB
Stable hosting, on which the social network EVILEG is located. For projects on Django we recommend VDS hosting.
14

Добрый день.

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

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
  • Feb. 25, 2020, 6:06 a.m.
  • (edited)

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

a
  • Feb. 25, 2020, 7:16 a.m.

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

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

a
  • Feb. 25, 2020, 7:17 a.m.
  • (edited)
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
  • Feb. 25, 2020, 7:23 a.m.
  • (edited)
// 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
  • Feb. 25, 2020, 7:24 a.m.

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

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

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

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

a
  • Feb. 25, 2020, 7:44 a.m.

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

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

Как-то так

pageStack.push(Qt.resolvedUrl("WebView.qml"))
var urlPath = "http://" + initWeb.getAddress()
pageStack.currentItem.setUrl(urlPath)

a
  • Feb. 25, 2020, 7:59 a.m.

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

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

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
  • Feb. 25, 2020, 8:06 a.m.

Да

Comments

Only authorized users can post comments.
Please, Log in or Sign up
Donate

Hello, Dear Users of EVILEG!!!

If the site helped you, then support the development of the site financially, please.

You can do it by following ways:

Thank you, Evgenii Legotckoi

A
April 6, 2020, 5:24 a.m.
Alexey

C++ - Test 001. The first program and data types

  • Result:86points,
  • Rating points6
R
April 5, 2020, 2:32 p.m.
Roman

C++ - Test 002. Constants

  • Result:91points,
  • Rating points8
AP
April 5, 2020, 2:31 p.m.
Alexander Peshkov

C++ - Test 001. The first program and data types

  • Result:60points,
  • Rating points-1
Last comments
April 3, 2020, 8:06 a.m.
Konstantin Grudnitskiy

Я надеюсь вы уже разобрались в чем дело, но если вдруг нет, то проблема состоит в том, что вы пытаетесь запустить программу из интерпретатора питона. Файл main.py это уже готова…
April 3, 2020, 6:18 a.m.
Konstantin Grudnitskiy

>>> text = 'hello world'>>> ' '.join(word for word in text.split()[:-1])'hello'>>> def remove_last_word(text):... return text and ' '.join(word for word in text.s…
March 27, 2020, 2:40 p.m.
Evgenij Legotskoj

Добрый день. В конце пятой статьи скачать можете.
March 27, 2020, 2:28 p.m.
mkdir _

Здравствуйте, а можно, пожалуйста, ссылку на целые исходники, если есть?
March 27, 2020, 4:36 a.m.
Evgenij Legotskoj

Скорее всего также, как и для установки всех остальных переменых в CMake, через использование set
Now discuss on the forum
s
April 6, 2020, 8:06 a.m.
shuric

Добрый день. Объясните пожалуйста ... ... допиливать стилевое оформление в прокси классе ... где именно копать ? В каком виртуальном методе лучше допиливать (если можно н…
April 6, 2020, 4:19 a.m.
Evgenij Legotskoj

Попробуй не переустанавливать материал, а просто менять цвет
April 5, 2020, 11:38 a.m.
Mihailll

Так работает windeployqt --qmldir E:\QTProject\testQmlAndCpp E:\test\build-testQmlAndCpp-Desktop_Qt_5_14_1_MinGW_32_bit-Release
April 5, 2020, 2:35 a.m.
Mihailll

Так работает console.log(textEmail.text) var str = textEmail.text; var n = str.search(/^((([0-9A-Za-z]{1}[-0-9A-z\.]{1,}[0-9A-Za-z]{1})|([0-9А-Яа-я]{1}[-0-9А-я\.]{1,}[…
April 3, 2020, 8:48 a.m.
Intruder

Евгений, добрый день. Спасибо!
EVILEG
About
Services
© EVILEG 2015-2019
Recommend hosting TIMEWEB