国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

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

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

瀏覽:78日期: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
主站蜘蛛池模板: 欧美成人自拍 | 狠狠色狠狠色综合久久一 | 三级在线国产 | 亚洲精品国产一区二区 | 亚洲精品一区二区在线观看 | 91久久青草精品38国产 | 久久久毛片免费全部播放 | 欧美一级久久久久久久大片 | 国产成年人在线观看 | 欧美亚洲日本 | 黄色美女网站免费 | 99re国产视频 | 成年人视频在线免费看 | 国产亚洲精品国看不卡 | 一级白嫩美女毛片免费 | 亚洲欧美日韩综合二区三区 | 欧美高清视频一区 | 成人入口 | 免费人成在线观看视频不卡 | 无毒在线| 国产亚洲女在线精品 | 日本红怡院在线 | 国产精品久久人人做人人爽 | 日本一级毛片片在线播放 | 免费观看a毛片一区二区不卡 | 深夜福利网站 | 殴美一级视频 | 成人男女网18免费0 成人男女网18免费看 | 91成人午夜性a一级毛片 | 色黄啪啪18周岁以下禁止观看 | 国产亚洲精品资源一区 | 久久免费毛片 | 国产精品一区伦免视频播放 | 欧美成人私人视频88在线观看 | 一级片在线免费看 | 久久精品道一区二区三区 | 成人a视频在线观看 | 国产精品国产三级在线高清观看 | 91玖玖 | 日韩毛毛片 | 欧美视频精品在线观看 |