AddEventListener работает в браузере, но не в Android

Я использую postMessage() функция для заполнения сообщения из мобильного приложения на поля веб-сайта. Я проверил это в браузере, и все работает отлично. Однако, когда я пытался протестировать на телефоне Android, ничего не заполнялось.

Сторона приложения:

var password = localStorage.getItem("password");
var language = localStorage.getItem("lang");
var credentials = username+'-'+password;
var msg = language+':'+username+'-'+password;
var loginWindow = window.open('https://link', '_blank', 'location=yes');

function giveMeUsername(){ 
    loginWindow.postMessage(msg, 'https://link');
    console.log('open window');
}

window.addEventListener('message', function(event) {
    alert('listener alert');
var message = event.data; 
if(message == 'giveMeUsername'){ 
    console.log('call giveMeUsernam');
giveMeUsername(); 
} 
}, false);

Эта линия alert('listener alert'); показывает предупреждение в браузере, но когда я тестирую его на устройстве Android (файл apk), ничего не отображается, и на сайт не отправляется сообщение.

Сторона сайта:

addScriptDeclaration("
    console.log('message received1:  ');
window.onload = function(){ 
window.opener.postMessage('giveMeUsername', '*'); 
console.log('message received2: '); 
};
function GetSubstringIndex(str, substring, n) {
    var times = 0, index = null;
    while (times < n && index !== -1) {
        index = str.indexOf(substring, index+1);
        times++;
    }
    return index;
}
    window.addEventListener('message', function(event) {
      console.log('message received3:  ');
      //if(event.origin !== 'http://appery.io') return;
      var message = event.data;
      console.log('message received5:  '+message);
      //var username = message.substr(0, message.indexOf('-'));
      var lang = message.slice(0,2);
      var username = message.substring(message.lastIndexOf(':')+1,message.lastIndexOf('-'));
      var password = message.substr(message.indexOf('-') + 1);    
      jQuery('input#username').val(username);
      jQuery('input#password').val(password);
       document.getElementById('loginbtn').click();
       var x = document.getElementById('loginbtn').name;
       console.log('message received6:  '+ x);
    }, false);
");
$document->addScriptDeclaration("
      console.log('message received6:  ');
");
?>

Я сбит с толку, так как не знаю ни одного метода отладки.apk. Я разрабатываю, тестирую и отлаживаю только в браузере, и все, что работает в браузере, обычно работает на Android.

1 ответ

Две вещи:

На устройстве (телефоне) Alert() функция не поддерживается. Вы должны использовать плагин Cordova диалоги. org.apache.cordova.dialogs

И я бы попробовал document.addEventListener и посмотрим, сработает ли это.

Другие вопросы по тегам