js启动Activity,web页面调用Activity页面

本文展示了一个HTML页面与JavaScript交互的示例,包括按钮触发的事件处理、数据填充到表格以及通过JavaScript调用原生应用功能。同时,介绍了如何在Android环境中实现WebView与JavaScript的双向通信。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

HTML页面代码

<script src="~/Scripts/common.js"></script>

<button οnclick="Test()">Test</button>
<button onClick="jumpToAppPages()" value="jumpToAppPages">跳转原生页面</button>

<div id="chartContainer1" style="width: 98%; height: 600px;overflow:auto">
    <table id="tbList" class="table table-responsive table-bordered" style="width:95%;color:white;background-color:transparent;border-collapse: collapse;">
        <thead>
            <tr>
                <td>Barcode        </td>
                <td>Scan Date      </td> 
            </tr>
        </thead>
        <tbody></tbody>
    </table>
</div> 

<script type="text/javascript">
    var x = 0;
    function GetScanCode(barcode) {
        var trtd = "<tr>" +
              "<td>{0}</td> " +
              "<td>{1}</td> " + 
           "</tr>"
        var day1 = new Date();
        day1.setDate(day1.getDate() - 1);
        var Yesterday = day1.Format("yyyy-MM-dd");
        var rows = String.format(trtd, barcode, Yesterday);

        $("#tbList tbody").append(rows);
    }

    function Test() {
        GetScanCode(x++)
    }

    function jumpToAppPages()
    {
        test.jump();
    }

</script>



定义一个类用于js调用

    public class TestInterFace{
        Intent intent = null;
        private Context mContext;
        public TestInterFace(Context context){
            this.mContext = context;
        }

        @JavascriptInterface  //这个必须加,否则不能调用
        public  void jump(){
            intent = new Intent(mContext, TestActivity.class);
            startActivityForResult(intent, SCAN_CODE_REQUEST_CODE);
        }
    }

        mWebview.getSettings().setJavaScriptEnabled(true); 
        mWebview.loadData("", "text/html", null);
        mWebview.addJavascriptInterface(new TestInterFace(WebActivity.this),"test");
        mWebview.loadUrl("http://192.168.155.1:8102/Machine/Scancode/");
        //设置不用系统浏览器打开,直接显示在当前Webview
        mWebview.setWebViewClient(new WebViewClient() {
            @Override
            public boolean shouldOverrideUrlLoading(WebView view, String url) {
                view.loadUrl(url);
                return true;
            }
        });


评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值