簡體   English   中英

Phonegap Java調用Javascript函數

[英]Phonegap Java call Javascript Function

我目前正在為Android開發一個hello世界類型的Phonegap應用程序,其中我從本地android代碼中調用了javascript函數來設置我應用程序中段落之一的文本。

我有一個在應用程序的html中定義的javascript函數,應用程序加載后,我想從我的活動中調用它。 該功能只是在我的應用程序中設置段落的文本。 我無法使它正常工作。

這是我的Java活動代碼:

public class MyPhoneGapActivity extends DroidGap {

    public DroidGap c;
    public LoadInfo info;

    @SuppressLint("SetJavaScriptEnabled") 
    @JavascriptInterface
    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        super.init();
        c = this;
        appView.getSettings().setJavaScriptEnabled(true);
        appView.getSettings().setJavaScriptCanOpenWindowsAutomatically(true);
        appView.loadUrl("file:///android_asset/www/index.html");

        appView.setWebViewClient(new WebViewClient() {
            public void onPageFinished(WebView view, String url) {
                MyPhoneGapActivity.this.runOnUiThread(new Runnable() {
                    public void run() {
                        c.sendJavascript("javascript:getMassTimes()");
                    }
                });
            }
        });
    }
}

這是我的javascript和html代碼:

<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<meta name="viewport"
    content="initial-scale=1, maximum-scale=1, user-scalable=no, width=device-width">
<title>Ionic Seed App</title>
<link href="lib/css/ionic.css" rel="stylesheet">

<link href="css/app.css" rel="stylesheet">
<link href="lib/css/mycss.css" rel="stylesheet">
<script src="lib/js/ionic.js"></script>
<script src="lib/js/angular/angular.js"></script>
<script src="lib/js/angular/angular-animate.js"></script>
<script src="lib/js/angular/angular-sanitize.js"></script>
<script src="lib/js/angular-ui/angular-ui-router.js"></script>
<script src="lib/js/ionic-angular.js"></script>
<script src="js/app.js"></script>
<script src="js/services.js"></script>
<script src="js/controllers.js"></script>
<script src="http://code.jquery.com/jquery-2.1.0.js"></script>
</head>
<body ng-app="myApp">
    <script type="text/javascript">
        function getMassTimes() {
            document.getElementById("massTimes").textContent = "This is some text";
        }
    </script>
    <div>
        <header-bar title="Saint David the King"
            class="bar bar-header bar-energized">
        <h1 class="title">Saint David the King</h1>
        </header-bar>
        <br>
        <content scroll="true" has-header="true" width="100%" height="100%"
            id="content"> <img alt="Saint David the King"
            src="file:///android_asset/www/img/saintdavidthekingbackground2.png"
            width="100%" /> <br>
        <p id="massTimes">
        </p>
        </content>
    </div>
</body>
</html>

我做錯什么了嗎? 我看過這些網站:

解決-從Java調用javascript函數

如何從Java代碼調用JavaScript函數

https://groups.google.com/forum/?fromgroups=#!topic/android-developers/1o9PgfmyRd8

http://www.jumpbyte.com/2012/phonegap-native-to-javascript/

使用PhoneGap從Android進行Java語言調用

如何使用phonegap插件從android調用javascript函數

我已經嘗試過使用它們,但是我無法使它正常工作。

任何幫助表示贊賞!

替換c.sendJavascript("javascript:getMassTimes()"); myBrowser.loadUrl("javascript:getMassTimes()");

這解決了我的問題。

如果要將字符串從活動傳遞給javascript,請使用

String msgToSend = "Hello World!"; myBrowser.loadUrl("javascript:callFromActivity(\\""+msgToSend+"\\")");

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM