阿里Weex 集成到Android

推薦使用 18.0版本

1. 使用Android Studio 新建項目

2. 使用gradle集成

dependencies {
    .......
    implementation 'com.android.support:recyclerview-v7:27.1.1'
    implementation 'com.android.support:support-v4:27.1.1'
    implementation 'com.android.support:appcompat-v7:27.1.1' 
    implementation 'com.alibaba:fastjson:1.1.46.android'
    implementation 'com.taobao.android:weex_sdk:0.18.0@aar'
}

http://jcenter.bintray.com/com/taobao/android/weex_sdk/0.18.0/

這是weex_sdk的maven倉庫地址,有可能會變更,可以自行查找

3. 添加混淆規(guī)則

-keep class com.taobao.weex.bridge.**{*;}
-keep class com.taobao.weex.dom.**{*;}
-keep class com.taobao.weex.adapter.**{*;}
-keep class com.taobao.weex.common.**{*;}
-keep class * implements com.taobao.weex.IWXObject{*;}
-keep class com.taobao.weex.ui.**{*;}
-keep class com.taobao.weex.ui.component.**{*;}
-keep class com.taobao.weex.utils.**{
    public <fields>;
    public <methods>;
    }
-keep class com.taobao.weex.view.**{*;}
-keep class com.taobao.weex.module.**{*;}
-keep public class * extends com.taobao.weex.common.WXModule{*;}

4. 在Application中初始化

WXSDKEngine.initialize(this, new InitConfig.Builder().build());

5. 在MainActivity中使用weex頁面

public class MainActivity extends AppCompatActivity implements IWXRenderListener{

    WXSDKInstancemWXSDKInstance;

    @Override

    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        mWXSDKInstance =new WXSDKInstance(this);
        mWXSDKInstance.registerRenderListener(this);
        /**
        * WXSample 可以替換成自定義的字符串,針對埋點有效。
        * template 是.we transform 后的 js文件。
        * option 可以為空,或者通過option傳入 js需要的參數(shù)。例如bundle js的地址等。
        * jsonInitData 可以為空。
        * width 為-1 默認(rèn)全屏,可以自己定制。
        * height =-1 默認(rèn)全屏,可以自己定制。
        */

        mWXSDKInstance.renderByUrl("com.xy.weex", "http://192.168.31.79:8081/dist/second.js", null, null, WXRenderStrategy.APPEND_ASYNC);
    }

    @Override
    public void onViewCreated(WXSDKInstance instance, View view) {
        setContentView(view);
    }

    @Override
    public void onRenderSuccess(WXSDKInstance instance, int width, int height) {
    }

    @Override
    public void onRefreshSuccess(WXSDKInstance instance, int width, int height) {
    }

    @Override
    public void onException(WXSDKInstance instance, String errCode, String msg) {
    }

    @Override
    protected void onResume() {
        super.onResume();
        if(mWXSDKInstance!=null){
            mWXSDKInstance.onActivityResume();
        }
    }

    @Override
    protected void onPause() {
        super.onPause();
        if(mWXSDKInstance!=null){
             mWXSDKInstance.onActivityPause();
        }
    }

    @Override
    protected void onStop() {
    super.onStop();
        if(mWXSDKInstance!=null){
            mWXSDKInstance.onActivityStop();
        }
    }

    @Override
    protected void onDestroy() {
        super.onDestroy();
        if(mWXSDKInstance!=null){
            mWXSDKInstance.onActivityDestroy();
        }
    }
}

6. 編譯vue頁面

image
image

使用 weex 命令編譯新建的 second.vue 文件, js文件編譯到dist目錄,-m 參數(shù)為壓縮js文件

7. 運行APP查看效果

如果沒什么意外的話,可以看到APP和網(wǎng)頁打開的效果是一致的

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容