2016-10-01 271 views
0

嗨我第一次使用科尔多瓦。 我想创建一个应用程序来显示我的网站。科尔多瓦InAppBrowser不工作

这里是我的科尔多瓦命令来创建应用程序:

cordova create myapp 
cd myapp 
cordova platform add android --save 
cordova plugin add cordova-plugin-inappbrowser --save 

和index.html:

<html> 
    <head> 
     <!-- 
     Customize this policy to fit your own app's needs. For more guidance, see: 
      https://github.com/apache/cordova-plugin-whitelist/blob/master/README.md#content-security-policy 
     Some notes: 
      * gap: is required only on iOS (when using UIWebView) and is needed for JS->native communication 
      * https://ssl.gstatic.com is required only on Android and is needed for TalkBack to function properly 
      * Disables use of inline scripts in order to mitigate risk of XSS vulnerabilities. To change this: 
       * Enable inline JS: add 'unsafe-inline' to default-src 
     --> 
     <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="user-scalable=no, initial-scale=1, maximum-scale=1, minimum-scale=1, width=device-width"> 
     <link rel="stylesheet" type="text/css" href="css/index.css"> 
     <title>Hello World</title> 
    </head> 
    <body> 
     <div class="app"> 
      <h1>Apache Cordova</h1> 
      <div id="deviceready" class="blink"> 
       <p class="event listening">Connecting to Device</p> 
       <p class="event received">Device is Ready</p> 
      </div> 
     </div> 
     <script type="text/javascript" src="cordova.js"></script> 
     <script type="text/javascript" src="js/index.js"></script> 
    <script type="text/javascript"> 
     document.addEventListener("deviceready", onDeviceReady, false); 
     function onDeviceReady() { 
      window.open = cordova.InAppBrowser.open; 
      var ref = cordova.InAppBrowser.open('http://apache.org', '_self', 'location=yes'); 
     } 
    </script> 
    </body> 
</html> 

和config.xml文件:

<?xml version='1.0' encoding='utf-8'?> 
<widget id="io.cordova.hellocordova" version="1.0.0" xmlns="http://www.w3.org/ns/widgets" xmlns:cdv="http://cordova.apache.org/ns/1.0"> 
    <name>HelloCordova</name> 
    <description> 
     A sample Apache Cordova application that responds to the deviceready event. 
    </description> 
    <author email="[email protected]" href="http://cordova.io"> 
     Apache Cordova Team 
    </author> 
    <content src="index.html" /> 
    <plugin name="cordova-plugin-whitelist" spec="1" /> 
    <access origin="*" /> 
    <allow-intent href="http://*/*" /> 
    <allow-intent href="https://*/*" /> 
    <allow-intent href="tel:*" /> 
    <allow-intent href="sms:*" /> 
    <allow-intent href="mailto:*" /> 
    <allow-intent href="geo:*" /> 
    <platform name="android"> 
     <allow-intent href="market:*" /> 
    </platform> 
    <platform name="ios"> 
     <allow-intent href="itms:*" /> 
     <allow-intent href="itms-apps:*" /> 
    </platform> 
    <engine name="android" spec="~5.2.2" /> 
    <plugin name="cordova-plugin-inappbrowser" spec="~1.5.0" /> 
</widget> 

,所以我建立我的应用,但不错误,但当我什么都没有运行在我的应用程序中显示除了设备准备好了

+0

你添加了Cordova白名单插件吗? – Gandhi

+0

为什么你把这个句子放入“ref”var?尝试删除,只是把cordova.InAppBrowser.open('http://apache.org','_self','location = yes'); –

+0

任何错误分享? – johnborges

回答

3

我得到了一个解决方案,我把你的“OnDeviceready”代码放入在它的index.js文件中创建的函数中。 所以,请尝试使用下面的代码

index.html中

<body> 
     <div class="app"> 
      <h1>Apache Cordova</h1> 
      <div id="deviceready" class="blink"> 
       <p class="event listening">Connecting to Device</p> 
       <p class="event received">Device is Ready</p> 
      </div> 
     </div>   
     <script type="text/javascript" src="js/index.js"></script> 

     <script type="text/javascript" src="cordova.js"></script> 

    </body> 

和index.js文件搜索部分,其中定义了“OnDeviceReady”功能,并更换到如下

onDeviceReady: function() { 
     app.receivedEvent('deviceready'); 
      window.open = cordova.InAppBrowser.open; 
      cordova.InAppBrowser.open('http://apache.org', '_self', 'location=yes'); 
    }, 

希望它有效,如果您使用的模拟器或Android设备的版本大于4.4,您可以在浏览器中使用Chrome的检查器(chrome:// inspect /#devices)对其进行测试和调试,以查看控制台的错误和日志。

+0

谢谢你,这个诀窍对我很有用 – Uahmed