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个回答

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

u010997144
Panda也疯狂 用ajax解决了!直接用js专递变量过去的话,接收到的是引号内的值,从App传过去的变量无法传入到后台!谢谢啦!
3 年多之前 回复
Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
立即提问
相关内容推荐