QWebChannel Class

원격 HTML 클라이언트에 QObject를 노출합니다. 더 보기...

Header: #include <QWebChannel>
qmake: QT += webchannel
Inherits: QObject

속성

공용 기능

QWebChannel(QObject *parent = nullptr)
virtual ~QWebChannel()
QBindable<bool> bindableBlockUpdates()
QBindable<int> bindablePropertyUpdateInterval()
bool blockUpdates() const
void deregisterObject(QObject *object)
int propertyUpdateInterval() const
void registerObject(const QString &id, QObject *object)
void registerObjects(const QHash<QString, QObject *> &objects)
QHash<QString, QObject *> registeredObjects() const
void setBlockUpdates(bool block)
void setPropertyUpdateInterval(int ms)

공용 슬롯

void connectTo(QWebChannelAbstractTransport *transport)
void disconnectFrom(QWebChannelAbstractTransport *transport)

신호

void blockUpdatesChanged(bool block)

상세 설명

QWebChannel은 C++ 애플리케이션과 HTML/JavaScript 애플리케이션 사이의 간극을 메워줍니다. QObject 파생 객체를 QWebChannel에 게시하고 HTML 측에서 qwebchannel.js를 사용하면 QObject 의 속성 및 공용 슬롯과 메서드에 투명하게 액세스할 수 있습니다. 수동 메시지 전달 및 데이터 직렬화가 필요하지 않으며, C++ 측의 속성 업데이트 및 신호 방출이 원격으로 실행되는 HTML 클라이언트에 자동으로 전송됩니다. 클라이언트 측에서는 게시된 모든 C++ QObject 에 대해 JavaScript 객체가 생성됩니다. 이는 C++ 객체의 API를 미러링하므로 직관적으로 사용할 수 있습니다.

QWebChannel은 QFuture 을 투명하게 지원합니다. 클라이언트가 QFuture 를 반환하는 메서드를 호출하면 QWebChannel은 QFuture 이 완료된 후에만 QFuture 결과가 포함된 응답을 보냅니다.

QMetaType::registerConverter() 를 사용하여 QJsonValue 로의 변환기를 정의하여 JSON 으로의 유형 사용자 지정 변환이 지원됩니다. QJsonValue 에서 구체적인 유형으로의 사용자 지정 변환은 QJsonValue 이 예상 형식과 일치하지 않으면 실패해야 합니다. 그렇지 않으면 QWebChannel이 기본 변환 메커니즘으로 돌아갈 수 없습니다. 자바스크립트 측에서도 사용자 정의 변환기를 사용할 수 있습니다.

C++ QWebChannel API를 사용하면 로컬 또는 원격 컴퓨터에서 실행할 수 있는 모든 HTML 클라이언트와 통신할 수 있습니다. 유일한 제한은 HTML 클라이언트가 qwebchannel.js 에서 사용하는 JavaScript 기능을 지원해야 한다는 것입니다. 따라서 기본적으로 모든 최신 HTML 브라우저 또는 node.js와 같은 독립형 JavaScript 런타임과 상호 작용할 수 있습니다.

선언적 WebChannel API 도 존재합니다.

Qt WebChannel 독립형 예제, JavaScript APIQMetaType::registerConverter()도 참조하세요 .

속성 문서

[bindable] blockUpdates : bool

참고: 이 속성은 QProperty 바인딩을 지원합니다.

true 으로 설정하면 업데이트가 차단되고 원격 클라이언트는 속성 변경에 대한 알림을 받지 못합니다.

이 속성을 false 으로 설정하여 업데이트가 다시 차단 해제되면 변경 사항이 기록되어 클라이언트에 전송됩니다. 기본적으로 업데이트는 차단되지 않습니다.

[bindable] propertyUpdateInterval : int

참고: 이 속성은 QProperty 바인딩을 지원합니다.

이 속성은 속성 업데이트 간격을 보유합니다.

이 간격을 양수 값으로 설정하여 밀리초 단위의 다른 간격으로 변경할 수 있습니다. 속성 업데이트는 일괄 처리되어 간격이 만료된 후에 전송됩니다. 0으로 설정하면 단일 이벤트 루프 실행 내에서 발생하는 업데이트가 일괄 처리되어 다음 실행 시 전송됩니다. 음수이면 업데이트가 즉시 전송됩니다. 기본값은 50밀리초입니다.

멤버 함수 문서

[explicit] QWebChannel::QWebChannel(QObject *parent = nullptr)

주어진 parent 로 QWebChannel 객체를 생성합니다.

QWebChannel은 QWebChannelAbstractTransport 에 연결해야만 완전히 작동한다는 점에 유의하십시오. HTML 클라이언트는 또한 qwebchannel.js.

[virtual noexcept] QWebChannel::~QWebChannel()

QWebChannel 를 파괴합니다.

[slot] void QWebChannel::connectTo(QWebChannelAbstractTransport *transport)

QWebChannel 을 지정된 transport 객체에 연결합니다.

그러면 전송 객체가 C++ 애플리케이션과 원격 HTML 클라이언트 간의 통신을 처리합니다.

QWebChannelAbstractTransportQWebChannel::disconnectFrom()도 참조하세요 .

[invokable] void QWebChannel::deregisterObject(QObject *object)

QWebChannel 에서 주어진 object 의 등록을 취소합니다.

원격 클라이언트는 지정된 객체에 대한 destroyed 신호를 수신합니다.

참고: 이 함수는 메타객체 시스템과 QML을 통해 호출할 수 있습니다. Q_INVOKABLE 을 참조하세요.

QWebChannel::registerObjects(), QWebChannel::registerObject() 및 QWebChannel::registeredObjects()도 참조하세요 .

[slot] void QWebChannel::disconnectFrom(QWebChannelAbstractTransport *transport)

transport 객체에서 QWebChannel 연결을 끊습니다.

QWebChannel::connectTo()도 참조하세요 .

[invokable] void QWebChannel::registerObject(const QString &id, QObject *object)

QWebChannel 에 단일 객체를 등록합니다.

object 의 속성, 시그널 및 공용 메서드가 원격 클라이언트에 게시됩니다. 그러면 id 식별자를 가진 객체가 생성됩니다.

BINDABLE 이지만 NOTIFY 신호가 없는 프로퍼티는 클라이언트 측에서 프로퍼티 업데이트가 작동하지만 변경 알림에 대한 콜백을 등록하는 메커니즘은 없습니다.

참고: 현재 제한 사항은 클라이언트가 초기화되기 전에 객체를 등록해야 한다는 것입니다.

참고: 이 함수는 메타 객체 시스템과 QML을 통해 호출할 수 있습니다. Q_INVOKABLE 을 참조하세요.

QWebChannel::registerObjects(), QWebChannel::deregisterObject() 및 QWebChannel::registeredObjects()도 참조하세요 .

void QWebChannel::registerObjects(const QHash<QString, QObject *> &objects)

QWebChannel 에 개체 그룹을 등록합니다.

객체의 속성, 시그널 및 공개 호출 가능한 메서드가 원격 클라이언트에 게시됩니다. 그런 다음 objects 맵에서 키로 사용되는 식별자를 가진 개체가 구성됩니다.

참고: 현재 제한 사항은 클라이언트가 초기화되기 전에 객체를 등록해야 한다는 것입니다.

QWebChannel::registerObject(), QWebChannel::deregisterObject() 및 QWebChannel::registeredObjects()도 참조하세요 .

QHash<QString, QObject *> QWebChannel::registeredObjects() const

원격 클라이언트에 게시된 등록된 객체의 맵을 반환합니다.

QWebChannel::registerObjects(), QWebChannel::registerObject() 및 QWebChannel::deregisterObject()도 참조하세요 .

© 2025 The Qt Company Ltd. Documentation contributions included herein are the copyrights of their respective owners. The documentation provided herein is licensed under the terms of the GNU Free Documentation License version 1.3 as published by the Free Software Foundation. Qt and respective logos are trademarks of The Qt Company Ltd. in Finland and/or other countries worldwide. All other trademarks are property of their respective owners.