weex小菜鳥(niǎo)一只,最近在用weex做項(xiàng)目,其中Android端進(jìn)行界面跳轉(zhuǎn)所采用的方案是,將編寫(xiě)好的weex界面通過(guò)webpack打包生成js文件,然后將這些js文件放置在Android項(xiàng)目的assets目錄下進(jìn)行跳轉(zhuǎn)加載。跳轉(zhuǎn)的weex代碼為:
var url = weex.config.bundleUrl url = url.split('/').slice(0, -1).join('/') + '/' + path + '.js' navigator.push({ url: url, animated: 'true' })
然后就一直跳轉(zhuǎn)不成功,看了下weex navigator.push()的源碼發(fā)現(xiàn)這個(gè)默認(rèn)是加載網(wǎng)絡(luò)的url,所以在Android里面正確的跳轉(zhuǎn)方式應(yīng)該是跳轉(zhuǎn)activity,在跳轉(zhuǎn)的activity里面重新進(jìn)行跳轉(zhuǎn)目標(biāo)地址的渲染,上網(wǎng)搜發(fā)現(xiàn)需要在AndroidManifest.xml文件的activity定義里如下設(shè)置:
<intent-filter>
<action android:name="android.intent.action.VIEW"/>
<action android:name="com.alibaba.weex.protocol.openurl"/>
<category android:name="android.intent.category.DEFAULT"/>
<category android:name="com.taobao.android.intent.category.WEEX"/>
<data android:scheme="http"/>
<data android:scheme="https"/>
<data android:scheme="file"/>
</intent-filter>
`
后來(lái)發(fā)現(xiàn)上面的這些配置如果是通過(guò)webpack生成的Android項(xiàng)目會(huì)自帶這些 = =!
在activity中可以通過(guò)
Uri uri = getIntent().getData();
獲取到跳轉(zhuǎn)的目標(biāo)路徑,然后再按照這個(gè)路徑進(jìn)行渲染就能夠?qū)崿F(xiàn)加載本地assets中的界面了