亚洲精品久久久中文字幕-亚洲精品久久片久久-亚洲精品久久青草-亚洲精品久久婷婷爱久久婷婷-亚洲精品久久午夜香蕉

您的位置:首頁技術文章
文章詳情頁

weex的web組件,當src為變量時在Android端無法加載

瀏覽:74日期:2024-02-20 11:42:26

問題描述

我在使用weex的web時,把src設為一個變量,在Android端,webView無法加載成功。we代碼如下:

<template><tm-navpage title=’{{title}}’ listenning_rigth_button_click=true> <web id=’toomao-web’ src=’{{src}}’ style=’width: 750; height: 1206;’ onpagefinish=’pagefinish’></web> <tm-loading if=’loading’></tm-loading></tm-navpage> </template><script> data: {src: ’’, // web加載鏈接url: ’’, // url參數userInfo: ’’,title: ’’,loading: true,canGoBack: false, // 記錄當前webView的加載信息 }, created() {this.url = decodeURIComponent(getUrlParams(this, ’url’)); }</script>

Android端的web實現主要如下:

@Deprecated public WXWeb(WXSDKInstance instance, WXDomObject dom, WXVContainer parent, String instanceId, boolean isLazy) {this(instance,dom,parent,isLazy); } public WXWeb(WXSDKInstance instance, WXDomObject dom, WXVContainer parent, boolean isLazy) {super(instance, dom, parent, isLazy);createWebView(); } protected void createWebView(){mWebView = new WXWebView(getContext()); } @Override protected View initComponentHostView(@NonNull Context context) {mWebView.setOnErrorListener(new IWebView.OnErrorListener() { @Override public void onError(String type, Object message) {fireEvent(type, message); }});mWebView.setOnPageListener(new IWebView.OnPageListener() { @Override public void onReceivedTitle(String title) {if (getDomObject().getEvents().contains(Constants.Event.RECEIVEDTITLE)) { Map<String, Object> params = new HashMap<>(); params.put('title', title); fireEvent(Constants.Event.RECEIVEDTITLE, params);} } @Override public void onPageStart(String url) {if ( getDomObject().getEvents().contains(Constants.Event.PAGESTART)) { Map<String, Object> params = new HashMap<>(); params.put('url', url); fireEvent(Constants.Event.PAGESTART, params);} } @Override public void onPageFinish(String url, boolean canGoBack, boolean canGoForward) {if ( getDomObject().getEvents().contains(Constants.Event.PAGEFINISH)) { Map<String, Object> params = new HashMap<>(); params.put('url', url); params.put('canGoBack', canGoBack); params.put('canGoForward', canGoForward); fireEvent(Constants.Event.PAGEFINISH, params);} }});return mWebView.getView(); } @Override public void destroy() {super.destroy();getWebView().destroy(); } @Override protected boolean setProperty(String key, Object param) {switch (key) { case Constants.Name.SHOW_LOADING:Boolean result = WXUtils.getBoolean(param,null);if (result != null) setShowLoading(result);return true; case Constants.Name.SRC:String src = WXUtils.getString(param,null);if (src != null) setUrl(src);return true;}return super.setProperty(key,param); } @WXComponentProp(name = Constants.Name.SHOW_LOADING) public void setShowLoading(boolean showLoading) {getWebView().setShowLoading(showLoading); } @WXComponentProp(name = Constants.Name.SRC) public void setUrl(String url) {if (TextUtils.isEmpty(url) || getHostView() == null) { return;}if (!TextUtils.isEmpty(url)) { loadUrl(getInstance().rewriteUri(Uri.parse(url), URIAdapter.WEB).toString());} } public void setAction(String action) {if (!TextUtils.isEmpty(action)) { if (action.equals(GO_BACK)) {goBack(); } else if (action.equals(GO_FORWARD)) {goForward(); } else if (action.equals(RELOAD)) {reload(); }} }private void fireEvent(String type, Object message) {if (getDomObject().getEvents().contains(Constants.Event.ERROR)) { Map<String, Object> params = new HashMap<>(); params.put('type', type); params.put('errorMsg', message); fireEvent(Constants.Event.ERROR, params);} } private void loadUrl(String url) {getWebView().loadUrl(url); } private void reload() {getWebView().reload(); } private void goForward() {getWebView().goForward(); } private void goBack() {getWebView().goBack(); } private IWebView getWebView() {return mWebView; }問題

在調試的過程中,發現setProperty方法只會走一次,就是在設置的時候, 當src從新賦值之后,web并不會去刷新url從新加載。求如何實現當src變化 時,web可以去從新加載,

嘗試過refreshData方法,發現也不會調用。

@Override public void refreshData(WXComponent component) {super.refreshData(component);component.getDomObject().getAttrs(); }

問題解答

回答1:

我突然怎么覺得是你的寫法問題。。。src=’{{src}}’ 改為 :src=’src’

回答2:

src屬性接受一個字符串,當你需要用變量的時候,對應vue的語法是v-bindsrc=’{{src}}’實際上是傳了一個{{src}}的字符串進去,肯定解析不了所以要用:src=’variable’而且v-bind不止接受變量,還可以寫表達式

我看了一下你的代碼你那個onPageFinish如果是事件的話應該是要綁定v-on的,也就是應該寫成@onPageFinish

標簽: web
主站蜘蛛池模板: 99热在线获取最新地址 | 91大神精品长腿在线观看网站 | 在线观看亚洲精品专区 | 日本不卡中文字幕 | 国产三级在线播放不卡 | 国产欧美日韩视频怡春院 | 欧美特黄特刺激a一级淫片 欧美特黄高清免费观看的 欧美爱片 | 国产成人夜间影院在线观看 | 欧美日韩国产在线人成dvd | 久久精品亚洲一级毛片 | 九九在线精品视频 | 中文字幕一区在线播放 | 91精品国产亚洲爽啪在线观看 | 999国产一区二区三区四区 | 免费在线日韩 | 911香蕉视频 | 我要看一级黄色录像 | 久久99热只有视精品6国产 | 亚洲一区二区三区四区热压胶 | 九草在线视频 | 色在线免费视频 | a毛片在线看片免费 | 美乳在线播放 | 亚洲欧美日韩中文字幕在线一 | 国产高清在线a视频大全凹凸 | 亚洲国产精品自产拍在线播放 | 网红思瑞一区二区三区 | 国产一区二区三区手机在线观看 | 日韩欧美影视 | 嗯!啊!使劲用力在线观看 | 久久成人小视频 | 福利一区二区三区视频在线观看 | 骚骚精品免费看 | 中国一级特黄特级毛片 | 欧美一区二区三区免费 | 日韩亚洲欧美综合 | 九九香蕉 | 成 人 黄 色 视频播放1 | 久久国产精品久久久久久久久久 | 国产裸舞凸点福利小视频 | 一区二区国产在线播放 |