Android与H5的交互问题

一、Android带数据到H5中

1、如果Android中的数据传输到H5界面中,目前是需要记录登录状态。只需要在h5接收的链接中添加token值:

例如:

String token = SharedPreferencesUtils.getString("token", "", getActivity());
if (!TextUtils.isEmpty(token)) {
    Intent intent = new Intent(getActivity(), HtmlActivity.class);
    intent.putExtra("url", "http://www.ceshi.com/activity/enterRotate.html?token=" + token_two);
    intent.putExtra("title", "测试");
    startActivity(intent);
    getActivity().overridePendingTransition(R.anim.activity_next_in, R.anim.activity_next_out);
}

这样就能够将你的Android端登录状态带过去,在H5处理的时候就不会再次让用户登录。

2、H5内部页面跳转,怎么控制点击一次返回按钮直接返回到Android界面的问题。主要的使用webview中的cangoBack方法。

 首先你仍然需要处理Android机中底部的返回按钮。

重写onkeyDown方法:如下:
@Override
public boolean onKeyDown(int keyCode, KeyEvent event) {
    if (keyCode == KeyEvent.KEYCODE_BACK && wvdetail.canGoBack()) {
        wvdetail.goBack();// 返回前一个页面
        return true;
    }
  然后你的H5页面的title_bar仍然是你自己设置的,设置返回按钮的onclick事件:



代码实现如下:
mFrBack.setOnClickListener(new View.OnClickListener() {
    @Override
    public void onClick(View v) {
        if (wvdetail.canGoBack()) {
            wvdetail.goBack();
        } else {
            finish();
        }
    }
});

这些代码是放在你加载H5里的Activity中的,而且需要有WebView控件哦!!!总结一下涨姿势

二、H5的数据交互到Android中(也就是记录在H5的登录态,并且在Android端使用此登录态)

你需要让H5端在其javascript代码中给你传输值:

function jsLayoutAndroid()
{
    String token="dddd";
    window.myObj.setToken(token)
}

在Android端创建一个类:

public class JavaScriptObject {

    private Context mContxt;
    private String token;

    public JavaScriptObject(Context mContxt) {
        this.mContxt = mContxt;
    }

    public String getToken() {
        return token;
    }


//切记下面这个引用一定要用
    @JavascriptInterface
    public void setToken(String token) {
        this.token= token;
        SharedPreferencesUtils.putString("token", token, mContxt);
        System.out.println("token----" + token);
    }

}

在你加载H5的Activity中设置如下:使用的是WebView

   WebSettings settings = wvdetail.getSettings();
   settings.setJavaScriptEnabled(true);
   url = getIntent().getStringExtra("url");
    wvdetail.loadUrl(url);
wvdetail.addJavascriptInterface(new JavaScriptObject(getApplication()), "myObj");

项目中是在返回时调用其javascript带回token值
        mFrBack.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                if (wvdetail.canGoBack()) {
                    wvdetail.goBack();
                } else {
                    wvdetail.loadUrl("javascript:jsLayoutAndroid()");
                    finish();
                }
            }
        });
//返回按键
public boolean onKeyDown(int keyCode, KeyEvent event) {
        if (keyCode == KeyEvent.KEYCODE_BACK && wvdetail.canGoBack()) {
            wvdetail.goBack();// 返回前一个页面
            return true;
        }
        wvdetail.loadUrl("javascript:jsLayoutAndroid()");
        return super.onKeyDown(keyCode, event);
    }
  • 7
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 6
    评论
评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值