Невозможно получить json значений из объекта сообщения websocket - PullRequest
0 голосов
/ 17 января 2020

Я хотел бы получать сообщения от подключения к веб-сокету и показывать их как уведомления pu sh, например:

socket.onmessage = msg => {
  if( 'Notification' in window){
    if (Notification.permission === 'granted') {
        navigator.serviceWorker.ready.then(function(registration) {
        doNotify(msg);
        });
    }
    else{
        Notification.requestPermission()
            .then(function(result) {
                console.log(result);  //granted || denied
                if( Notification.permission == 'granted'){ 
                    doNotify();
                }
            })
            .catch( (err) => {
                console.log(err);
            });
    }

}
};

function doNotify(msg) {
  console.log('msg to deal with  is:', msg) ;
  console.log('type of message: ', typeof msg);
  let msgJ = JSON.stringify(msg);
  console.log('msg in json format:', msgJ) ;
  console.log('type of msgJ: ', typeof msgJ);
  console.log('sender:', msgJ.data.sender) ;
  console.log(' body:', msgJ.data.body) ;

  let title = "Message from" +  msgJ.data.sender;
  let body = msgJ.data.body;
  let options = {
    title:  title,
    body:   body,
    vibrate: [100, 200, 100]
  }
  let n = new Notification(title, options);

}

Однако я не могу извлечь title и body от полученных сообщений.

Вот результаты журнала консоли:

msg to deal with  is: MessageEvent {isTrusted: true, data: "{"sender":"tomtom","body":"Hi there"}↵", origin: "ws://127.0.0.1:8080", lastEventId: "", source: null, …}
type of message:  object
msg in json format: {"isTrusted":true}
type of msgJ:  string
socket.js?1579263492:52 Uncaught (in promise) TypeError: Cannot read property 'sender' of undefined
    at doNotify (socket.js?1579263492:52)
    at socket.js?1579263492:17 

Что здесь может быть не так? Как я могу это исправить?

1 Ответ

1 голос
/ 17 января 2020

MessageEvent.data выглядит как строка JSON, как уже указывал @chg, поэтому вам необходимо преобразовать ее в объект.

let data = JSON.parse(msg.data);
let title = "Message from " +  data.sender;
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...