Hbuilder (H5+) plus.webview 预加载

                                       Hbuilder (H5+)  plus.webview 预加载

plus.webview.create   经常会用到  webview 来显示 Web网页,但是有时候 会出现白屏, 而且有些低端机器 时间还挺长。这个时候就需要用到预加载。

 

应为 我们要用的 plus.webview  创建完毕, 关闭不同 close(),  改用 hide(). 以此 提升效率,

在hide() 之前 为了 解决 下次打开  不残留上次页面 还要把 当前页面 置为空白

webview.loadData('')

这里有几个 核心函数 贴出来

 

  1. 预加载 进入应用的时候 就创建

function webviewInit() {

  if (window.plus) {
    let view = plus.webview.getWebviewById('h5View');
    if (!view) {
      createWebView()
    }
  }
}

 

我的代码里面包含  两个按钮 不用的可以去掉

实现方法

Hbuilder (H5+) plus.webview 预加载_第1张图片

function createWebView() {

  ///创建 webView
  let webview = plus.webview.create('', 'h5View', {
    contentAdjust: false
  }, null);
  webview.setStyle({
    'zindex': 30,
    'titleNView': false,
  })





  //关闭按钮
  let bitmap_menu = new plus.nativeObj.Bitmap("closedmenu");
  bitmap_menu.loadBase64Data(
    ""
  )
  let leftPos = (window.screen.width - 80) + 'px';
  let viewClose = new plus.nativeObj.View('webViewClose', {
    top: '5px',
    left: leftPos,
    width: "50px",
    height: "37px"
  });
  viewClose.drawBitmap(bitmap_menu, {
    top: "0",
    left: "0",
    width: "82px",
    height: "62px"
  })
  viewClose.interceptTouchEvent(true);
  viewClose.addEventListener("click", function(e) {
    //console.log('=====> webViewClose click')
    webview.onloaded = function() {}
    plus.webview.getWebviewById('h5View').loadData('')
    plus.webview.getWebviewById('h5View').hide()

    viewClose.hide()

  }.bind(this));


  //外部打开按钮
  let bitmap_menuOpen = new plus.nativeObj.Bitmap("openmenu");
  bitmap_menuOpen.loadBase64Data(
    ""
  )
  let pos = (window.screen.width - 80 - 50) + 'px';
  let viewOpen = new plus.nativeObj.View('webViewOpen', {
    top: '5px',
    left: pos,
    width: "50px",
    height: "37px"
  });
  viewOpen.drawBitmap(bitmap_menuOpen, {
    top: "0",
    left: "0",
    width: "82px",
    height: "62px"
  })
  viewOpen.interceptTouchEvent(true);
  viewOpen.addEventListener("click", function(e) {
    //console.log('=====> webViewOpen click')
    plus.runtime.openURL(webViewUrl)
    plus.webview.getWebviewById('h5View').hide()
    viewOpen.hide()
  }.bind(this));


}

 

调用接口

function openUrlPay(url, data) {
  webViewUrl = url
  plus.navigator.setFullscreen(true);
  plus.device.setWakelock(true)

  let webview = plus.webview.getWebviewById('h5View');
  if (!webview) {
    console.log("webview 预加载失败")
    webviewInit()
    return
  }


  webview.addEventListener("hide", function() {
    //console.log("======>hide")
    plus.nativeObj.View.getViewById('webViewClose').hide()
    plus.nativeObj.View.getViewById('webViewOpen').hide()
    plus.navigator.setFullscreen(false);
    plus.device.setWakelock(false)
  }, false);


  // webview.onloaded = function() {
  //   plus.nativeObj.View.getViewById('webViewClose').show()
  //   plus.nativeObj.View.getViewById('webViewOpen').show()
  //   //plus.webview.getWebviewById('h5View').show()
  //   //webview.show()
  // }
  // webview.onhide = function() {
  //   plus.nativeObj.View.getViewById('webViewClose').hide()
  //   plus.nativeObj.View.getViewById('webViewOpen').hide()
  //   plus.navigator.setFullscreen(false);
  //   plus.device.setWakelock(false)
  // }

  webview.loadURL(url)
  webview.show()
  plus.nativeObj.View.getViewById('webViewClose').show()
  plus.nativeObj.View.getViewById('webViewOpen').show()
  //webview.append(  plus.webview.open(url))


  webview.evalJS(
    "plus.key.addEventListener('backbutton',function () {});"
  );
  window.openGift = function() {
    plus.webview.getWebviewById('h5View').hide();
    router.push("/gift");
  }


}

 

你可能感兴趣的:(Vue)