相关疑难解决方法(0)

从活动类调用webview中的javascript函数

编辑:这个剪辑最终工作.我以前一直在尝试这个,但实际上我的javascript遇到了一个范围问题.我在document.onready中定义了appBack().只需将该函数重新定义为*window.*appBack = function().完成业务.希望这有助于某人.

public boolean onKeyDown(int keyCode, KeyEvent event) {
    if (keyCode == KeyEvent.KEYCODE_BACK) {
        WebView.loadUrl("javascript:appBack()");
        return true;
    }
    return super.onKeyDown(keyCode, event);
}
Run Code Online (Sandbox Code Playgroud)

在webview应用程序中,后退导航是使用自定义JS函数appBack()处理的.我一直试图找到一种方法来拦截android物理后退按钮并调用该javascript函数.这是我的活动文件.它非常基本,设置webview并监听后退按钮点击.目前,当用户单击此物理后退按钮时,它将运行mWebView.goBack().我想在哪里执行javascript:appBack()

package com.stgeorgeplc.app;

import android.app.Activity;
import android.os.Bundle;
import android.view.KeyEvent;
import android.webkit.WebView;


public class StGeorgePLCliteActivity extends Activity {
    /** Called when the activity is first created. */
    WebView mWebView;
    @Override

    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.main);

        mWebView = (WebView) findViewById(R.id.webview);
        mWebView.getSettings().setJavaScriptEnabled(true);
        mWebView.getSettings().setBuiltInZoomControls(true);

        mWebView.loadUrl("file:///android_asset/www/index.html");
    }

    public boolean onKeyDown(int keyCode, KeyEvent event) {
        if (keyCode == KeyEvent.KEYCODE_BACK) …
Run Code Online (Sandbox Code Playgroud)

javascript android interface webview onkeydown

6
推荐指数
0
解决办法
2852
查看次数

Android PhoneGap 1.7调用javascript函数

好的,我需要给一些背景知识.首先我使用的是带有PhoneGap 1.7的jquery-mobile.我编写了一个使用ServerSocket对象的非常简单的Java服务器.在Android手机上,我连接到服务器,这样服务器通过套接字发送数据.这部分正在运作.

我坚持的部分是我打算通过该套接字发送数据,这将需要在接收数据时更新jquery移动UI.


答:西蒙是一个巨大的帮助,我在他的帮助下想出来并遵循本教程

真正打击我的部分是在PhoneGap插件本身产生的线程.一旦我意识到,一切都到位了.但是,对于任何感兴趣的人都是代码.请记住,我从教程中学到了很多东西.我还包括我为测试这些概念而创建的非常简单的Java服务器.我想也许这将有助于将来的某个人.请记住,这基本上是一个概念证明.

我需要修改这个插件以满足我的实际需求:

Android Activity:import org.apache.cordova.DroidGap;

import android.os.Bundle;

public class ISSAndroidActivity extends DroidGap {
    /** Called when the activity is first created. */
    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        super.loadUrl("file:///android_asset/www/index.html");
    }
}
Run Code Online (Sandbox Code Playgroud)

PhoneGap插件:

import java.io.ObjectInputStream;
import java.io.ObjectOutputStream;
import java.net.InetSocketAddress;
import java.net.Socket;
import java.net.SocketAddress;
import java.net.SocketException;

import org.apache.cordova.api.*;
import org.apache.cordova.api.PluginResult;
import org.apache.cordova.api.PluginResult.Status;
import org.json.JSONArray;
import org.json.JSONException;
import org.json.JSONObject;

import android.util.Log;

public class InvokeJavaScriptPlugin extends Plugin {
    public static String PLUGIN_TAG = "InvokeJavaScriptPlugin";
    public static String PROCESS_DATA_ACTION …
Run Code Online (Sandbox Code Playgroud)

javascript java jquery cordova

5
推荐指数
1
解决办法
5344
查看次数

标签 统计

javascript ×2

android ×1

cordova ×1

interface ×1

java ×1

jquery ×1

onkeydown ×1

webview ×1