三步搞定:Vue.js調(diào)用Android原生操作
第一步: Android對Js的接口,新建AndroidInterfaceForJs.js
import android.content.Context;
import android.os.Build;
import android.os.Handler;
import android.os.Looper;
import android.support.annotation.RequiresApi;
import android.util.Log;
import android.webkit.JavascriptInterface;
import android.webkit.ValueCallback;
import android.widget.Toast;
import com.just.agentweb.AgentWeb;
import com.yidumedical.ui.activity.PAWebActivity;
/**
* Created by shiby on 2018/1/24.
*/
public class AndroidInterfaceForJS {
private Handler deliver = new Handler(Looper.getMainLooper());
private AgentWeb agent;
private Context context;
public AndroidInterfaceForJS(AgentWeb agent, Context context) {
this.agent = agent;
this.context = context;
}
@JavascriptInterface
public void callAndroid(final String msg) {
deliver.post(new Runnable() {
@Override
public void run() {
Log.i("Info", "main Thread:" + Thread.currentThread());
Toast.makeText(context.getApplicationContext(), "" + msg, Toast.LENGTH_LONG).show();
}
});
Log.i("Info", "Thread:" + Thread.currentThread());
}
}
第二步: 給WebView中的window注入對象(例子使用的是AgentWeb)
private void init(){
mAgentWeb = AgentWeb
.with(this)//傳入Activity or Fragment
.setAgentWebParent(mLinearLayout, new LinearLayout.LayoutParams(-1, -1))//傳入AgentWeb 的父控件 ,如果父控件為 RelativeLayout , 那么第二參數(shù)需要傳入 RelativeLayout.LayoutParams ,第一個參數(shù)和第二個參數(shù)應該對應。
.useDefaultIndicator()// 使用默認進度條
.defaultProgressBarColor() // 使用默認進度條顏色
.createAgentWeb()//
.ready()
.go(baseURL);
//注入對象
mAgentWeb.getJsInterfaceHolder().addJavaObject("android",new AndroidInterfaceForJS(mAgentWeb,this.getApplicationContext()));
AgentWebSettings agentWebSettings = mAgentWeb.getAgentWebSettings();
agentWebSettings.getWebSettings().setDomStorageEnabled(true);
}
注入對象:
//注入對象
mAgentWeb.getJsInterfaceHolder().addJavaObject("android",new AndroidInterfaceForJS(mAgentWeb,this.getApplicationContext()));
第三步:在Vue里面直接調(diào)用方法(簡單粗暴法):
window.android.callAndroid('調(diào)用成功,耶?。?!')
考慮到項目的可維護性,一般不這樣寫。
優(yōu)雅法:
新建app.js
const android = window.android
export { android }
將 window.android存在該模塊,方便更改
然后在需要的.js或者.vue文件中,導入app模塊,然后使用
import {android} from '../app'
try {
android.callAndroid('調(diào)用成功,耶!??!')
} catch (e) {
console.log('出現(xiàn)錯誤, 如果在非android環(huán)境下訪問, 出現(xiàn)該警告是正常的.')
}
補充知識:vue與原生安卓相互調(diào)用
最近公司有做直播類的項目,由于直播框架限制,限制所用的技術是vue搭建的H5頁面嵌入到原生安卓中。由于之前沒有過類似的混合開發(fā)經(jīng)驗,所以今天寫篇博客加深下印象。
vue.js調(diào)用安卓方法
先將vue項目放到一個內(nèi)網(wǎng)地址或者外網(wǎng)地址中,然后安卓端通過“webView.loadUrl()”將vue項目引入。安卓端將要調(diào)用的方法名暴露在window對象中,由vue直接在methods中調(diào)用并攜帶參數(shù)。
methods:{
goPublish(){
//將vue項目引入至安卓代碼中,安卓方法暴露在window中,vue中可以直接用window去調(diào)取方法。
window.android.callAndroidMethod('1','2')
}
}
安卓調(diào)用vue.js中的方法
同樣的vue也需要把方法添加到window中去,再由安卓端去調(diào)取方法。
created(){
//需要在created鉤子中將方法添加到window對象中
window.setFun = this.setFun;
},
methods:{
setFun(arg) {
//arg: 原生調(diào)用Vue時傳值(arg)給Vue
console.log("獲取到android的傳參:" + arg);
},
}
以上就是vue與安卓端項目調(diào)用的大致方法,有用詞不當?shù)牡胤酵:也涣咧刚OM芙o大家一個參考,也希望大家多多支持腳本之家。
相關文章
Vue使用watch同時監(jiān)聽多個值的實現(xiàn)方法示例
這篇文章主要為大家介紹了Vue中使用watch同時監(jiān)聽多個值的實現(xiàn)方法示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2023-05-05
在Vue3項目中使用Vuex進行狀態(tài)管理的詳細教程
在?Vue?3?中使用?Vuex?進行狀態(tài)管理是一個很好的實踐,特別是在涉及到多個組件間共享狀態(tài)的情況,下面是如何在?Vue?3?項目中設置和使用?Vuex?的教程,包括?state,?mutations,?actions,?getters?的概念及其用途,需要的朋友可以參考下2024-09-09
vue項目啟動出現(xiàn)cannot GET /服務錯誤的解決方法
這篇文章主要介紹了vue項目啟動出現(xiàn)cannot GET /服務錯誤的解決方法,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2020-04-04

