Cordova 2.2 + ChildBrowser 3.0.4 + iOS ==失败

时间:2012-11-19 21:59:23

标签: ios cordova childbrowser

我只是想在我的PhoneGap应用中设置一个功能,在外部浏览器中打开某些链接。代码似乎在Android上运行正常(我没有在Windows Phone上测试,因为插件信息声称支持不存在,但是......),但每次我试图让它在iPhone上运行模拟器(iOS 5.1),它出现以下错误:

testCB[3332:c07] CDVPlugin class childbrowser.js (pluginName: ChildBrowser) does not exist.
testCB[3332:c07] ERROR: Plugin 'ChildBrowser' not found, or is not a CDVPlugin. Check your plugin mapping in Cordova.plist.
testCB[3332:c07] -[CDVCommandQueue executePending] [Line 102] FAILED pluginJSON = ["ChildBrowser1249404349","ChildBrowser","showWebPage",["http://www.apple.com",{"showLocationBar":true}]]

我看过各个论坛和这里,我一直看到有人提到更新Cordova.plist文件。很好,所以这就是(并注意,这是一个全新的Cordova应用程序,而不是升级或更新,我现在尝试使用测试应用程序,以排除我自己的应用程序中的难度):

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd">
<plist version="1.0">
<dict>
    <!-- the standard keys snipped -->
    <key>ExternalHosts</key>
    <array>
        <string>*</string>
    </array>
    <key>Plugins</key>
    <dict>
        <key>ChildBrowser</key>
        <string>childbrowser.js</string>
        <key>ChildBrowserCommand</key>
        <string>ChildBrowserCommand</string>
        <key>Device</key>
        <string>CDVDevice</string>
        <key>Logger</key>
        <string>CDVLogger</string>
        <key>Compass</key>
        <string>CDVLocation</string>
        <key>Accelerometer</key>
        <string>CDVAccelerometer</string>
        <key>Camera</key>
        <string>CDVCamera</string>
        <key>NetworkStatus</key>
        <string>CDVConnection</string>
        <key>Contacts</key>
        <string>CDVContacts</string>
        <key>Debug Console</key>
        <string>CDVDebugConsole</string>
        <key>Echo</key>
        <string>CDVEcho</string>
        <key>File</key>
        <string>CDVFile</string>
        <key>FileTransfer</key>
        <string>CDVFileTransfer</string>
        <key>Geolocation</key>
        <string>CDVLocation</string>
        <key>Notification</key>
        <string>CDVNotification</string>
        <key>Media</key>
        <string>CDVSound</string>
        <key>Capture</key>
        <string>CDVCapture</string>
        <key>SplashScreen</key>
        <string>CDVSplashScreen</string>
        <key>Battery</key>
        <string>CDVBattery</string>
        <key>Globalization</key>
        <string>CDVGlobalization</string>
    </dict>
</dict>
</plist>

(编辑)在我的index.html文件中,我已经包含了(我意识到这几乎是不言而喻的。我也意识到很多问题都是由那些不考虑首先尝试所有显而易见的东西的人发布的! ):

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

我的js电话看起来像:

onDeviceReady: function() {
    app.receivedEvent('deviceready');

    var link = document.getElementById('launchApple');
    console.log('derp?');

    if(link){
        //var cb = ChildBrowser.install();
        console.log("We're trying to add a click handler link");
        link.addEventListener('click', function() {
                              console.log('click');
                              window.plugins.childBrowser.openExternal('http://www.apple.com'); });
    }

},

当我点击链接时,我收到上述错误。

我尝试将childbrowser.js文件的大小写更改为ChildBrowser.js。 我试过在iPhone 6模拟器中运行它。 我的插件文件夹包含从https://github.com/alunny/ChildBrowser

下载的包中的所有文件

我已经清除了〜/ Library / Application Support中的缓存 我在项目上尝试过Clean。

有什么想法?我即将开始寻找一只好的山羊或鸡肉,以便快速牺牲“写一次,到处跑”的众神(我相当肯定他们是Loki的后裔,Trickster)!

2 个答案:

答案 0 :(得分:3)

好的,有几件事。一个是个人的“DERP!”但其余的我只是简单的文档和奇怪的实现。

在首页(https://github.com/alunny/ChildBrowser)上,.openExternal()的文档中有一条说明,说明这只是Android版。这是我的“derp!”

(我还没有找到为什么有onOpenExternal的钩子,据说只有iOS版...)

其次,抛弃所有告诉您添加childbrowser.js作为ChildBrowser插件项的字符串的文档。你的插件应该是这样的:

<key>ChildBrowser</key>
<string>ChildBrowserCommand</string>
<key>ChildBrowserCommand</key>
<string>ChildBrowserCommand</string>

小问题:

  • target =“_ blank”适用于iPhone上的<a>标签。
  • 确保将ChildBrowser(字符串)ChildBrowserCommand项目放在插件列表中, NOT childbrowser.js!
  • .openExternal()为iPhone工作 NOT (此时),但是.showWebPage()确实(或者,如果你想在iPhone上使用openExternal()功能,我想你可以在锚标记上设置target =“_ blank”,并且仅对不支持它的平台使用preventDefault(),例如Android。)

答案 1 :(得分:0)

cordova.js脚本之后,将childbrowser.js添加到HTML文件中,如下所示:

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