真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

Android路由框架ARouter怎么用-創(chuàng)新互聯(lián)

今天小編給大家分享一下Android路由框架ARouter怎么用的相關(guān)知識點(diǎn),內(nèi)容詳細(xì),邏輯清晰,相信大部分人都還太了解這方面的知識,所以分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后有所收獲,下面我們一起來了解一下吧。

公主嶺網(wǎng)站制作公司哪家好,找成都創(chuàng)新互聯(lián)!從網(wǎng)頁設(shè)計(jì)、網(wǎng)站建設(shè)、微信開發(fā)、APP開發(fā)、成都響應(yīng)式網(wǎng)站建設(shè)公司等網(wǎng)站項(xiàng)目制作,到程序開發(fā),運(yùn)營維護(hù)。成都創(chuàng)新互聯(lián)從2013年成立到現(xiàn)在10年的時(shí)間,我們擁有了豐富的建站經(jīng)驗(yàn)和運(yùn)維經(jīng)驗(yàn),來保證我們的工作的順利進(jìn)行。專注于網(wǎng)站建設(shè)就選成都創(chuàng)新互聯(lián)。

一、添加依賴和初始化框架

1、添加依賴

在需要使用ARouter的module中添加如下代碼:

1.1、java版本的依賴
android {
    defaultConfig {
        ...
        javaCompileOptions {
            annotationProcessorOptions {
                arguments = [moduleName :project.getName() ]
            } }
    }
}

dependencies {
    api 'com.alibaba:arouter-api:1.5.1'
    annotationProcessor 'com.alibaba:arouter-compiler:1.5.1'
}
1.2、kotlin版本的依賴
plugins {
    ...
    id 'kotlin-kapt'
}

dependencies {
    ...
    implementation 'com.alibaba:arouter-api:1.5.1'
    kapt 'com.alibaba:arouter-compiler:1.5.1'
}

題外話: implementation 和 api 關(guān)鍵字,在Android studio3.0版本中,曾經(jīng)的 compile 關(guān)鍵字被棄用,而 api 則是 compile 的替代品, api 與 compile 沒有區(qū)別。但新官方推薦使用 implementation 來代替 compile 關(guān)鍵字,據(jù)說 implementation 會使Android studio的編譯速度更快呦。

而 implementation 和 api 關(guān)鍵字的區(qū)別則在于用 implementation 來聲明的依賴包只限于當(dāng)前module內(nèi)部使用,對于依賴其module的模塊是無法使用到該依賴包的。而用 api 來聲明依賴包時(shí),依賴于該module的模塊可以正常使用其模塊內(nèi)的依賴包。

在這里,由于我是將其放入一個(gè)公共的module,來讓app module進(jìn)行依賴,因此使用 api 關(guān)鍵字。若沒有對項(xiàng)目進(jìn)行組件化,則可以使用 implementation 關(guān)鍵字進(jìn)行依賴。

2、初始化SDK

//初始化ARouter框架
private boolean isDebugARouter = true;//ARouter調(diào)試開關(guān)
if (isDebugARouter) {
    //下面兩行必須寫在init之前,否則這些配置在init中將無效
    ARouter.openLog();
    //開啟調(diào)試模式(如果在InstantRun模式下運(yùn)行,必須開啟調(diào)試模式!
    // 線上版本需要關(guān)閉,否則有安全風(fēng)險(xiǎn))
    ARouter.openDebug();
}
//官方推薦放到Application中初始化
ARouter.init((Application) mContext);

二、ARouter的簡單使用

1、界面跳轉(zhuǎn)

1.1、Activity界面跳轉(zhuǎn)

目標(biāo)Activity添加注釋(跳轉(zhuǎn)語句,路由路徑建議寫成常量,創(chuàng)建路由表進(jìn)行統(tǒng)一管理。)

@Route(path = "/app/login")
public class LoginActivity extends AppCompatActivity {

發(fā)送Activity實(shí)現(xiàn)跳轉(zhuǎn)到

ARouter.getInstance().build("/app/login").navigation();
1.2、獲取fragment實(shí)例
//目標(biāo)界面
@Route(path = "/app/fragment")
public class EmptyFragment extends BaseFragment {
}

//啟動界面
Fragment fragment= (Fragment) ARouter.getInstance().build("/app/fragment").navigation();
FragmentManager manager = getSupportFragmentManager();
FragmentTransaction transaction = manager.beginTransaction();
transaction.add(R.id.fl_fragment_content, fragment);
transaction.commit();
1.3、注意事項(xiàng)

如果像我一樣對項(xiàng)目進(jìn)行了組件化的同學(xué)就會發(fā)現(xiàn),此時(shí)跳轉(zhuǎn)并沒有成功,而是彈出錯(cuò)誤提示。

Android路由框架ARouter怎么用

這是因?yàn)榻M件化后,即時(shí)我們使用了 api 作為依賴的關(guān)鍵字,但仍需在使用ARouter的其他module中配置代碼。這里一般習(xí)慣的做法是把a(bǔ)router-api的依賴放在基礎(chǔ)服務(wù)的module里面,因?yàn)榧热挥玫搅私M件化,那么肯定是所有的module都需要依賴arouter-api庫的,而arouter-compiler的依賴需要放到每一個(gè)module里面。

java

android {
    defaultConfig {
        ...
        javaCompileOptions {
            annotationProcessorOptions {
                arguments = [moduleName :project.getName() ]
            } }
    }
}

dependencies {
    annotationProcessor 'com.alibaba:arouter-compiler:1.5.1'
}

kotlin

plugins {
    ...
    id 'kotlin-kapt'
}

dependencies {
    ...
    kapt 'com.alibaba:arouter-compiler:1.5.1'
}

否則無法匹配路由,并且在使用withObject方法攜帶對象時(shí)也會報(bào)錯(cuò),這個(gè)后面再說,再試一次發(fā)現(xiàn)界面成功跳轉(zhuǎn)。關(guān)于注釋 @Route 的 path 參數(shù),也需要注意規(guī)范,必須要以“/”開頭,并且路徑至少為兩級,不然會編譯不通過或者報(bào)錯(cuò)。

Android路由框架ARouter怎么用

意思是路徑必須以“/”開頭,并且包含的值超過2個(gè)“/”。

2、攜帶基本參數(shù)的界面跳轉(zhuǎn)

使用方法如下,傳入鍵值對

Bundle bundle = new Bundle();
bundle.putString("bundleStringKey", "bundleStringValue");

ARouter.getInstance().build("/app/login")
             .withString("stringKey", "stringValue")
             .withInt("intKey", 100)
             .withBoolean("booleanKey", true)
             .withBundle("bundle", bundle)
             .navigation();

目標(biāo)界面使用 @Autowired 注解進(jìn)行注入

@Route(path = "/app/login")
public class LoginActivity extends AppCompatActivity {
    @Autowired
    String stringKey;
    @Autowired
    int intKey;
    @Autowired
    boolean booleanKey;
    @Autowired
    Bundle bundle;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_login);
        //注入ARouter
        ARouter.getInstance().inject(this);
        
        Log.e(TAG, stringKey + "..." + intKey + "..." + booleanKey);
        Log.e(TAG, bundle.getString("bundleStringKey"));
    }
}

注意:注入的屬性名要和之前攜帶的key值完全相同,并且要在需要注入的界面通過ARouter.getInstance().inject(this)注入ARouter,否則無法注入成功。建議將ARouter.getInstance().inject(this)操作放在BaseActivity的onCreate方法中進(jìn)行。既然有注入,就一定有資源的釋放,因此釋放資源在Application中進(jìn)行。

@Override
    public void onTerminate() {
        super.onTerminate();
        ARouter.getInstance().destroy();
    }

如果釋放資源放在BaseActivity的onDestroy方法中調(diào)用了 ARouter.getInstance().destroy( ) ; 在進(jìn)入目標(biāo)Activity之后,然后按back鍵返回原界面的時(shí)候,APP會報(bào)錯(cuò)崩潰,下面是崩潰日志:

Android路由框架ARouter怎么用

3、攜帶對象的界面跳轉(zhuǎn)

3.1、攜帶序列化對象的界面跳轉(zhuǎn)

攜帶 Serializable 和 Parcelable 序列化的對象

TestSerializableBean serializableBean = new TestSerializableBean();
serializableBean.setName("serializable");

TestParcelableBean parcelableBean = new TestParcelableBean();
parcelableBean.setName("parcelable");

ARouter.getInstance().build("/app/login")
        .withParcelable("parcelableBean", parcelableBean)
        .withSerializable("serializableBean", serializableBean)
        .navigation();

目標(biāo)界面

@Autowired
TestParcelableBean parcelableBean;
@Autowired
TestSerializableBean serializableBean;

@Override
protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_login);
        Log.e(TAG, parcelableBean + "");
        Log.e(TAG, serializableBean + "");
}

Android路由框架ARouter怎么用

我們發(fā)現(xiàn)Serializable序列化的對象為null,我們查看withSerializable方法發(fā)現(xiàn)其被裝進(jìn)了Bundle

public Postcard withSerializable(@Nullable String key, @Nullable Serializable value) {
        mBundle.putSerializable(key, value);
        return this;
    }

因此換一種方法來取值,發(fā)現(xiàn)打印成功

TestSerializableBean serializableBean = (TestSerializableBean) getIntent().getExtras().getSerializable("serializableBean");
Log.e(TAG, serializableBean + "");

Android路由框架ARouter怎么用

3.2、攜帶無序列化對象的界面跳轉(zhuǎn)

沒有進(jìn)行過序列化的對象也可以通過withObject對象進(jìn)行傳遞,接收方式相同

NormalTest normalTest = new NormalTest();
normalTest.setName("normal");
ARouter.getInstance().build("/app/login")
        .withObject("normalTest", normalTest)
        .navigation();

但是我們直接使用該方法運(yùn)行會報(bào)錯(cuò),分析源碼發(fā)現(xiàn)該方法中用到了SerializationService

public Postcard withObject(@Nullable String key, @Nullable Object value) {
        serializationService = ARouter.getInstance().navigation(SerializationService.class);
        mBundle.putString(key, serializationService.object2Json(value));
        return this;
    }

因此我們需要實(shí)現(xiàn)該服務(wù)

@Route(path = "/service/json")
public class JsonServiceImpl implements SerializationService {
    private Gson gson;

    @Override
    public  T json2Object(String input, Class clazz) {
        return gson.fromJson(input, clazz);
    }

    @Override
    public String object2Json(Object instance) {
        return gson.toJson(instance);
    }

    @Override
    public  T parseObject(String input, Type clazz) {
        return gson.fromJson(input, clazz);
    }

    @Override
    public void init(Context context) {
        gson = new Gson();
    }
}

我們可以在里面定義所需的json解析器,再次運(yùn)行成功打印該對象。那序列化的對象可以使用該方法傳遞嗎?

TestParcelableBean objParcelableBean = new TestParcelableBean();
objParcelableBean.setName("objParcelable");

TestSerializableBean objSerializableBean = new TestSerializableBean();
objSerializableBean.setName("objSerializable");

NormalTest normalTest = new NormalTest();
normalTest.setName("normal");

ARouter.getInstance().build("/app/login")
        .withObject("objParcelableBean", objParcelableBean)
        .withObject("objSerializableBean", objSerializableBean)
        .withObject("normalTest", normalTest)
        .navigation();

//目標(biāo)界面
@Autowired(name = "objParcelableBean")
TestParcelableBean objParcelableBean;
@Autowired(name = "objSerializableBean")
TestSerializableBean objSerializableBean;
@Autowired(name = "normalTest")
NormalTest normalTest;

Log.e(TAG, objParcelableBean + "");
Log.e(TAG, objSerializableBean + "");
Log.e(TAG, normalTest + "");

Android路由框架ARouter怎么用

我們發(fā)現(xiàn)用 Parcelable 序列化的對象為空,分析build的編譯文件

@Override
  public void inject(Object target) {
    serializationService = ARouter.getInstance().navigation(SerializationService.class);
    LoginActivity substitute = (LoginActivity)target;
    substitute.objParcelableBean = substitute.getIntent().getParcelableExtra("objParcelableBean");
    if (null != serializationService) {
      substitute.objSerializableBean = serializationService.parseObject(substitute.getIntent().getStringExtra("objSerializableBean"), new com.alibaba.android.arouter.facade.model.TypeWrapper(){}.getType());
    } else {
      Log.e("ARouter::", "You want automatic inject the field 'objSerializableBean' in class 'LoginActivity' , then you should implement 'SerializationService' to support object auto inject!");
    }
    if (null != serializationService) {
      substitute.normalTest = serializationService.parseObject(substitute.getIntent().getStringExtra("normalTest"), new com.alibaba.android.arouter.facade.model.TypeWrapper(){}.getType());
    } else {
      Log.e("ARouter::", "You want automatic inject the field 'normalTest' in class 'LoginActivity' , then you should implement 'SerializationService' to support object auto inject!");
    }
  }

我們可以看到唯獨(dú)通過 Parcelable 方式序列化的對象沒有使用SerializationService進(jìn)行解析,而是直接從Bundle去取,但我們并不是通過withParcelable方法去設(shè)置的值,因此取得的數(shù)據(jù)為null。

小結(jié):因此,為了方便我們的操作,沒有序列化和使用 Serializable 序列化的對象使用 withObject 方法傳遞,使用 Parcelable 方式序列化的對象則采用 withParcelable 方法進(jìn)行傳遞。

3.3、攜帶集合和數(shù)組的界面跳轉(zhuǎn)

集合和數(shù)組的界面跳轉(zhuǎn)統(tǒng)一使用 withObject 方法傳遞,并且能夠支持成員的各種序列化方式。

 List listNormal = new ArrayList<>();
 listNormal.add(new NormalTest());
 listNormal.add(new NormalTest());

 List listSerializable = new ArrayList<>();
 listSerializable.add(new TestSerializableBean());
 listSerializable.add(new TestSerializableBean());

 List listParcelable = new ArrayList<>();
 listParcelable.add(new TestParcelableBean());
 listParcelable.add(new TestParcelableBean());

 Map map = new HashMap<>();
 map.put("1", new NormalTest());
 map.put("2", new NormalTest());

 ARouter.getInstance().build("/app/login")
         .withObject("listNormal", listNormal)
         .withObject("listSerializable",listSerializable)
         .withObject("listParcelable",listParcelable)
         .withObject("map", map)
         .navigation();

 //目標(biāo)界面
 @Autowired
 List listNormal;
 @Autowired
 List listSerializable;
 @Autowired
 List listParcelable;
 @Autowired
 Map map;

 Log.e(TAG, listNormal + "");
 Log.e(TAG, listSerializable + "");
 Log.e(TAG, listParcelable + "");
 Log.e(TAG, map + "");

Android路由框架ARouter怎么用

4、界面跳轉(zhuǎn)回調(diào)

//啟動界面
ARouter.getInstance().build("/app/login")
        .navigation(MainActivity.this, REQUEST_CODE);

@Override
    protected void onActivityResult(int requestCode, int resultCode, @Nullable Intent data) {
        super.onActivityResult(requestCode, resultCode, data);
        if (requestCode == REQUEST_CODE&& resultCode == RESULT_CODE) {
            LogUtils.e(data.getStringExtra("data"));
        }
    }


//目標(biāo)界面
Intent intent = new Intent();
intent.putExtra("data", "resultData");
setResult(RESULT_CODE, intent);
finish();

以上就是“Android路由框架ARouter怎么用”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家閱讀完這篇文章都有很大的收獲,小編每天都會為大家更新不同的知識,如果還想學(xué)習(xí)更多的知識,請關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道。


分享標(biāo)題:Android路由框架ARouter怎么用-創(chuàng)新互聯(lián)
鏈接分享:http://weahome.cn/article/deshhg.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部