Как использовать Cordova InAppBrowser в HostedWebApps? - PullRequest
0 голосов
/ 22 марта 2019

У меня есть веб-сайт с 2 мобильными приложениями, отображаемыми с помощью Cordova, и они действительно отлично работают.Но у меня проблема:

Когда пользователь запускает внешнюю ссылку, он выходит из приложения и не имеет возможности вернуться в приложение ... (кроме закрытия и повторного открытия).

Я установил в приложении в соответствии с этому уроку .Звучит очень просто, но не работает ...

Консоль:

cordova plugin add cordova-plugin-inappbrowser

Ссылка (должна вызывать InAppBrowser - не работает):

 <a href="#" onclick="window.open('http://www.google.com', '_blank', 'location=yes', 'toolbar=yes'); return false;">www.google.com</a>

И я только что вспомнилчто мои приложения отображаются в технике Hosted Web App .И, возможно, это то, что InAppBrowser не работает: мы уже в веб-браузере?!

Я приведу ниже свой код конфигурации и код JS, вот учебник Microsoft, который помог мнев настройках приложения .

Цель: найти способ использовать InAppBrowser, потому что у нас много внешних ссылок на нашем сайте.

Любые идеи, пожалуйста?Большое спасибо !

Вот код:

Index.js

var app = {
    // Application Constructor
    initialize: function() {
    this.bindEvents();
    },
    bindEvents: function() {
        document.addEventListener('deviceready', this.onDeviceReady, false);
    },
    onDeviceReady: function() {
        app.receivedEvent('deviceready');

        // Here, we redirect to the web site.
        var targetUrl = "https://www.website.test/";
        var bkpLink = document.getElementById("bkpLink");
        bkpLink.setAttribute("href", targetUrl);
        bkpLink.text = targetUrl;
        window.location.replace(targetUrl);
},
    // Note: This code is taken from the Cordova CLI template.
    receivedEvent: function(id) {
        var parentElement = document.getElementById(id);
        var listeningElement = parentElement.querySelector('.listening');
        var receivedElement = parentElement.querySelector('.received');

        listeningElement.setAttribute('style', 'display:none;');
        receivedElement.setAttribute('style', 'display:block;');

        console.log('Received Event: ' + id);
    }
};

app.initialize();

App.js

/*global app, $on */
(function () {
  'use strict';

  /**
   * Sets up a brand new Todo list.
   *
   * @param {string} name The name of your new to do list.
   */
  function Todo(name) {
    this.storage = new app.Store(name);
    this.model = new app.Model(this.storage);
    this.template = new app.Template();
    this.view = new app.View(this.template);
    this.controller = new app.Controller(this.model, this.view);
  }

  var todo = new Todo('todos-vanillajs');

  function setView() {
    todo.controller.setView(document.location.hash);
  }
  $on(window, 'load', setView);
  $on(window, 'hashchange', setView);

    var onSuccess = function(position) {
        var geotext = document.getElementById('geotext');
        geotext.textContent = 'Latitude: ' + position.coords.latitude + '\n' +
          'Longitude: ' + position.coords.longitude;
    };

    var onError = function onError(error) {
    alert('code: '    + error.code    + '\n' +
          'message: ' + error.message + '\n');
    }

    var button = document.getElementById('geo');
    button.addEventListener("click", function(){
                          navigator.geolocation.getCurrentPosition(onSuccess, onError);
                          });


    function myOnDeviceReady() {
        if (navigator.connection.type == Connection.NONE) {
            navigator.notification.alert('An internet connection is required to continue');
        } else {
            window.location="https://www.website.test/";
        }
    }
    document.addEventListener("deviceready", myOnDeviceReady, false);

})();

Index.html

<!DOCTYPE html>
<html>
<head>

  <meta http-equiv="Content-Security-Policy" content="default-src 'self' data: gap: https://ssl.gstatic.com 'unsafe-eval'; style-src 'self' 'unsafe-inline'; media-src *">
  <meta name="format-detection" content="telephone=no">
  <meta name="msapplication-tap-highlight" content="no">
  <meta name="viewport" content="viewport-fit=cover, initial-scale=1, maximum-scale=1, user-scalable=no, width=device-width" />
  <meta charset="utf-8">
  <meta http-equiv="Content-Security-Policy" content="default-src 'self' data: gap: https://www.website.test/ https://ssl.gstatic.com 'unsafe-eval'; style-src 'self' 'unsafe-inline'; media-src *">
  <title>mysite</title>
  <link rel="stylesheet" href="node_modules/todomvc-common/base.css">
  <link rel="stylesheet" href="node_modules/todomvc-app-css/index.css">
  <link rel="stylesheet" type="text/css" href="css/overrides.css" />
</head>
<a id="bkpLink" href="https://www.website.test/" class="mysite_font">mysite</a>

  <div class="app">
      <img src="img/logo_gradient.png" style="width: 200px;">
      <div id="deviceready" class="blink">
          <p class="mysite_font event listening">Chargement de l'app...</p>
          <p class="mysite_font event received">Chargement...<br/>Merci de patienter quelques instants.</p>
      </div>
  </div>
  <script type="text/javascript" src="scripts/index.js"></script>
  <script type="text/javascript" src="cordova.js"></script>
  <script src="node_modules/todomvc-common/base.js"></script>
  <script src="js/helpers.js"></script>
  <script src="js/store.js"></script>
  <script src="js/model.js"></script>
  <script src="js/template.js"></script>
  <script src="js/view.js"></script>
  <script src="js/controller.js"></script>
  <script src="js/app.js"></script>
  <script type="text/javascript" src="js/index.js"></script>
</html>

1 Ответ

0 голосов
/ 03 апреля 2019

Исходя из вашего вопроса и последующих действий, я предполагаю, что вы загружаете файл yourwebsite.com в свое мобильное приложение, а затем на yourwebsite.com вы хотите открывать внешние ссылки, но сохраняете otherwebsite.com в своем приложении.Если я правильно понимаю, вы можете загрузить yourwebsite.com в свое мобильное приложение и открыть внешние ссылки с помощью inAppBrowser, отправив postMessage() обратно в мобильное приложение с внешней ссылкой.

Сначала загрузите на свой веб-сайт..com в пределах <iframe> в вашем мобильном приложении:

<iframe src="https://www.yourwebsite.com">

На yourwebsite.com при нажатии внешней ссылки (в моем примере это что-то с классом . external_url, и вы, скорее всего,вместо нескольких ссылок необходимо использовать querySelectorAll), захватить его с помощью JS и отправить значение href обратно в мобильное приложение с помощью postMessage():

document.querySelector('.external_url').addEventListener('click', function(event) {
  event.preventDefault(); // stops the user from loading this link
  var data = {'external_url': event.target.href};
  window.parent.postMessage(data, '*');
});

Вернувшись в свое мобильное приложение, вам необходимо прослушатьна входящий postMesssage().И активируйте inAppBrowser, чтобы открыть внешний URL-адрес, который был возвращен с yourwebsite.com.

window.addEventListener('message', function(event) {
  if (event.data.external_url) {
    window.cordova.InAppBrowser.open(event.data.external_url, '_blank', 'location=no');
  }
}, true);

Я не проверял этот код, но он должен указать вам правильное направление с некоторыми изменениями.

...