Panda也疯狂 2017-02-06 03:07 采纳率: 100%
浏览 1323
已采纳

Android WebView与Html交互问题

在Android App里,选择好参数,点击App内的一个Button后,
把参数传到部署在服务器上的html,html显示查询结果,该怎么实现呢?

HTML

 <%@ Page Language="C#" AutoEventWireup="true" CodeFile="index.aspx.cs" Inherits="index" %>

<!DOCTYPE html>
<html xmlns="http://www.w3.org/1999/xhtml">
<head runat="server">
<meta http-equiv="Content-Type" content="text/html; charset=utf-8"/>
    <title>测试</title>
    <script type="text/javascript">          
         function Myonclick() {
             alert("触发了onclick事件!");
         }
         function del() {
             alert("OK");
         }       

        function showFromHtml() {
            document.getElementById("id_input").value = "Java call Html";
        }

        function showFromHtml2(param) {
            document.getElementById("id_input2").value = "Java call Html : " + param;
        }

        function JavacallHtml2(param) {
            document.getElementById("id_input2").value = "Javas call Html : " + param;
        }


    </script>
</head>



<body>
    <form id="form1" runat="server">


<input type="button" value="HtmlcallJava" onclick="showFromHtml()" />
<input type="button" value="HtmlcallJava2" onclick="showFromHtml2()" />

<input id="id_input" style="width: 90%" type="text" value="null" />
<br />
<input type="button" value="JavacallHtml" onclick="window.jsObj.JavacallHtml()" />

<br />

<input id="id_input2" style="width: 90%" type="text" value="null" />
<br/>
<input type="button" value="JavacallHtml2" onclick="window.jsObj.JavacallHtml2()" />
    </form>
</body>
</html>

Android

 private static final String url = "http://xx.xx.x.xx/test/index.aspx";
    private WebView mWebView;
    private String Msg = null;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_web);

        Intent intent = getIntent();
        Msg = intent.getStringExtra("jobno");
        initView();
    }

    private void initView() {
        mWebView = (WebView) findViewById(R.id.web);
        mWebView.setWebChromeClient(new WebChromeClient());
        //或的WebView的Setting
        WebSettings settings = mWebView.getSettings();
        //设置支持js,看方法名字就知道啥意思
        settings.setJavaScriptEnabled(true);
        settings.setDefaultTextEncodingName("GBK");//设置字符编码
        mWebView.setScrollBarStyle(0);//滚动条风格,为0指滚动条不占用空间,直接覆盖在网页上
        mWebView.loadUrl("javascript:showInfoFromJava('" + Msg + "')");       
        //加载网页路径
        mWebView.loadUrl(url);
    }

上面的代码测试,无法获得从App传到THML的参数!

  • 写回答

1条回答 默认 最新

  • ljheee 2017-02-06 15:20
    关注

    http://xx.xx.x.xx/test/index.aspx
    这个地址,你用浏览器,可以实现访问吗?
    要在一个局域网

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥15 metadata提取的PDF元数据,如何转换为一个Excel
  • ¥15 关于arduino编程toCharArray()函数的使用
  • ¥100 vc++混合CEF采用CLR方式编译报错
  • ¥15 coze 的插件输入飞书多维表格 app_token 后一直显示错误,如何解决?
  • ¥15 vite+vue3+plyr播放本地public文件夹下视频无法加载
  • ¥15 c#逐行读取txt文本,但是每一行里面数据之间空格数量不同
  • ¥50 如何openEuler 22.03上安装配置drbd
  • ¥20 ING91680C BLE5.3 芯片怎么实现串口收发数据
  • ¥15 无线连接树莓派,无法执行update,如何解决?(相关搜索:软件下载)
  • ¥15 Windows11, backspace, enter, space键失灵