Placeholder text in QML TextEdit

10,598

Solution 1

The property doesn't exist on the Qt Quick input items. You can vote for the feature here.

In the meantime, you can use TextArea from Qt Quick Controls 2.

If you would rather use pure Qt Quick, you can do something similar to what the Controls do and add a Text item above the field:

import QtQuick 2.5
import QtQuick.Window 2.2

Window {
    width: 300
    height: 300
    visible: true

    TextEdit {
        id: textEdit
        width: 200
        height: 50

        property string placeholderText: "Enter text here..."

        Text {
            text: textEdit.placeholderText
            color: "#aaa"
            visible: !textEdit.text
        }
    }
}

Solution 2

This is kinda old but I found another necessity for Android builds. Since Android only send the text editing signal after you press ok in virtual keyboard, the placeholder remains there. So to avoid it, I recommend:

TextEdit {
    id: textEdit
    width: 200
    height: 50

    property string placeholderText: "Enter text here..."

    Text {
        text: textEdit.placeholderText
        color: "#aaa"
        visible: !textEdit.text && !textEdit.activeFocus // <----------- ;-)
    }
}

Solution 3

If you want one line input then why not use TextField ?

Share:
10,598
Herr von Wurst
Author by

Herr von Wurst

List item SOreadytohelp

Updated on June 09, 2022

Comments

  • Herr von Wurst
    Herr von Wurst about 2 years

    I am looking for a way to show a text hint stating the expected input as advice for the user. Take the Google search bar for example:

    enter image description here

    Is there a property I am missing, or is this something that has to be achieved through scripting?

  • GrecKo
    GrecKo over 7 years
    TextField from Qt Quick Controls 1 also does that.