欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

uniapp使用webview嵌入vue頁面及通信實現(xiàn)方式

 更新時間:2024年01月09日 16:30:51   作者:會說法語的豬  
項目中有需要嵌入其他H5的頁面的業(yè)務(wù)需求,這篇文章主要給大家介紹了關(guān)于uniapp使用webview嵌入vue頁面及通信實現(xiàn)方式的相關(guān)資料,文中通過代碼介紹的非常詳細(xì),需要的朋友可以參考下

前言

最近剛做的一個需求,web端(Vue)使用了FormMaking庫,F(xiàn)ormMaking是一個拖拉拽的動態(tài)設(shè)計表單、快速開發(fā)的一個東西,拖拽完之后最終可以導(dǎo)出一個很長的json,然后通過json再進(jìn)行回顯,快速開發(fā),但是因為FormMaking是基于Vue和ElementUI的,uniapp中不能直接使用,只能采用webview的方式進(jìn)行嵌入。就是把Vue項目中的要嵌入的頁面加入到白名單,也就是不需要登陸就可以訪問該頁面,直接將該頁面通過webview嵌入到uniapp中即可

本來想著是將uniapp中的token傳到webview頁面中,在要嵌入的webview頁面(Vue頁面)中去獲取json進(jìn)行渲染的,但是通過webview嵌入到uniapp中,在webview頁面去發(fā)請求會有問題,本來uniapp做的就少一些,更是第一次做webview,所以這兩天還是碰到不少坑。

最終方案就是在uniapp中獲取那一大串兒json,然后傳遞到webview頁面進(jìn)行渲染,然后提交表單的時候再通知webview頁面(Vue頁面)將表單json再傳遞給uniapp進(jìn)行提交。所以就涉及到了uniapp與webview之間的通信問題,接下來介紹:

1、uniapp中嵌入外部網(wǎng)頁:

<template>
  <view class="index">
    <web-view
      :update-title="false"
      :src="wvSrc"
    ></web-view>
  </view>
</template>
<script>
export default {
  data() {
    return {
      wvSrc: ""
    }
  },
  onLoad() {
    // #ifdef APP-PLUS
    this.wvSrc = `http://192.168.124.19:3000/#/index`;
    // #endif
  },
}
</script>
<style scoped>
.index {
  width: 100%;
  height: 100%;
  position: relative;
}
</style>

就是直接給src復(fù)制就可以。上面給webview標(biāo)簽設(shè)置了update-title為false,它默認(rèn)的是true,也就是默認(rèn)webview嵌入進(jìn)來上面的標(biāo)題會跟隨webview的自動更新,就會覆蓋掉uniapp自身的標(biāo)題,設(shè)置為false就不會覆蓋

2、uniapp向webview頁面?zhèn)髦?/h2>

2.1. 先看第一種:通過路徑傳遞 

就是在嵌入的時候就直接在后面拼接上參數(shù),但是這個最好只傳遞字符串,因為傳遞json對象的話在解析的時候可能會出問題,并不太推薦這種方式,如果只是一兩個簡短的字符串的話,還是可以的啦。

 uniapp頁面?zhèn)鬟f:

let tk = 'test_token'
let id = 'pppppppiiiiiigggg'
let status = 'start'
this.wvSrc = `http://192.168.124.19:3000/#/index?params=${tk}WFT${id}WFT${status}`

webview頁面接受: 

首先得先引入一下: 

 public/index.html

<script type="text/javascript" src="https://unpkg.com/@dcloudio/uni-webview-js@0.0.3/index.js"></script>

或者進(jìn)入瀏覽器輸入該地址,Ctrl + A, Ctrl + C, 復(fù)制粘貼到本地,然后引入本地也是可以的,但是引入的時候一定是 import uni from '你的路徑'

這樣我們?nèi)执蛴∫幌聈ni就會看到里面的方法: 

然后在monted里面監(jiān)聽UniAppJSBridgeReady方法,也就是Vue該頁面被嵌入到uniapp中的時候會觸發(fā),也就是可以使用uni的API了 

mounted(){
  console.log(uni)
  // 待觸發(fā) `UniAppJSBridgeReady` 事件后,即可調(diào)用 uni 的 API。
  document.addEventListener('UniAppJSBridgeReady', () => {
    console.log('UniAppJSBridgeReady-->')
    const [tk, id, status] = this.getQuery('params', 'hash').split('WFT')
    console.log(tk, 'tk-->>')
    console.log(id, 'id-->>')
    console.log(status, 'status-->>')
  })
},
methods: {
  // 解析url傳遞的參數(shù)
  getQuery(name, type = 'search') {
    // const reg = new RegExp("(^|&)" + name + "=([^&]*)(&|$)")
    // // const value = window.location.hash.substr(3).match(reg)
    // const value = window.location.search.substr(1).match(reg)
    // if (value) return decodeURIComponent(value[2])
    // return null
    
    // type取值 search | hash
    return window.location[type].split(`${name}=`)[1]
  }
}

如果你的Vue項目是hash模式路由參數(shù)就在window.lacation.hash中,如果不是就是window.location.search中,反正打印一下window.location就可以看到里面的信息了,再截取一下就OK了! 

2.2. 第二種:通過調(diào)用當(dāng)前的webview實例的evalJS方法

通過evalJS為這個子webview注入一段js。執(zhí)行內(nèi)部的邏輯

還有一點,webview優(yōu)先級很高,并且默認(rèn)都是全部覆蓋app的,而且直接對其修改樣式也是不起作用的,通過當(dāng)前的webview實例對象也可以對其修改樣式 

一般我在嵌入的時候,就會拿到當(dāng)前的webview實例,供后面使用

uniapp代碼 

// template代碼
<button @tap="submit" class="btn">啟動</button>

//script代碼
onLoad() {
  // #ifdef APP-PLUS
  this.wvSrc = `http://192.168.124.19:3000/#/index`
  setTimeout(() => {
    this.curWebview = this.$scope.$getAppWebview().children()[0]
    this.curWebview.setStyle({ height: '75%', scalable:true }) // scalable是否開啟雙指縮放
  }, 500) //如果是頁面初始化調(diào)用時,需要延時一下
  // #endif
},
methods: {
  //調(diào)用webview中的方法(注意getWebviewData一定是window上的方法,所以我們要在Vue頁面中將對應(yīng)的方法掛載到window上)
  submit() {
    let obj = { name: 'wft' }
    //傳遞的參數(shù)如果是引用類型,就要JSON.stringify轉(zhuǎn)一下,否則報錯
    this.curWebview.evalJS(`getWebviewData(${JSON.stringify(obj)})`)
  }
}

webview代碼 

<script>
export default {
  created() {
    window.getWebviewData = this.getData
  },
  methods: {
    //我們傳遞過來的是通過JSON.stringify轉(zhuǎn)過的,但是到這兒之后直接轉(zhuǎn)過來了,不需要我們再轉(zhuǎn)通過JSON.parse轉(zhuǎn)一下了,直接可以用
    getData(obj) {
      console.log(obj.name) // wft
    }
  }
}
</script>

這種方式傳遞參數(shù)還是很方便的,我這里方法名寫的getData,是因為我的業(yè)務(wù)里,在點擊按鈕的時候要拿到webview中的數(shù)據(jù),這樣我調(diào)用webview頁面的getData方法,獲取到數(shù)據(jù)然后再通過uni.postMessage傳遞到uniapp就可以了,也是我接下來要介紹的,webview頁面向uniapp傳遞 

三、webview向uniapp傳遞消息 

這個還是需要引入uni中的api,上面也有介紹 

<script type="text/javascript" src="https://unpkg.com/@dcloudio/uni-webview-js@0.0.3/index.js"></script>

通過uni.postMessage傳遞 

uni.postMessage({
  data: {
    info: {
      name: 'wft',
      age: 18
    }
  }
})

這個就很方便了,但是要注意,一定是上面的寫法,上面寫法我們真正傳遞的數(shù)據(jù)是info,data這個對象是必須要寫的,官網(wǎng)也有寫https://uniapp.dcloud.net.cn/component/web-view.html#web-view 

然后在uniapp中監(jiān)聽

//template代碼
<web-view :update-title="false" :src="wvSrc" @message="handlerMessage"></web-view>

//script代碼
// 接受提交參數(shù)
handlerMessage(event) {
  let { info } = event.detail.data[0]
  console.log(info.name, 'info>>') // wft
  console.log(info.age, 'info>>') // 18
}

就是這么接收的,很方便。 

有一點細(xì)節(jié)需要注意一下,就是上面代碼中我有使用了 // #ifdef APP-PLUS 和 // #endif

這個是判斷當(dāng)前是不是運行在app中的,因為uniapp平時開發(fā)調(diào)試可以運行在真機上也可以運行在瀏覽器上的,如果不加 // #ifdef APP-PLUS 和 // #endif 那么運行在瀏覽器上的時候就會報錯了,因為瀏覽器上是沒有this.$scope ,并不用說上面拿webview實例this.$scope.$getAppWebview().children()[0]了,這樣可以確保只在運行在真機上的時候才會用那些api。條件編譯處理多端差異,這是官網(wǎng),大家有興趣可以去瞅瞅

總結(jié) 

到此這篇關(guān)于uniapp使用webview嵌入vue頁面及通信實現(xiàn)方式的文章就介紹到這了,更多相關(guān)uniapp用webview嵌入vue頁面內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Js數(shù)組扁平化實現(xiàn)方法代碼總匯

    Js數(shù)組扁平化實現(xiàn)方法代碼總匯

    這篇文章主要介紹了Js數(shù)組扁平化實現(xiàn)方法代碼總匯,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2020-11-11
  • JavaScript數(shù)組深拷貝和淺拷貝的兩種方法

    JavaScript數(shù)組深拷貝和淺拷貝的兩種方法

    在使用JavaScript對數(shù)組進(jìn)行操作的時候,我們經(jīng)常需要將數(shù)組進(jìn)行備份,事實證明如果只是簡單的將它賦予其他變量,那么我們只要更改其中的任何一個,然后其他的也會跟著改變,這就導(dǎo)致了問題的發(fā)生。
    2014-04-04
  • Object.defineProperty()?完整指南示例詳解

    Object.defineProperty()?完整指南示例詳解

    本文深入理解`Object.defineProperty()`的方法,包括基礎(chǔ)概念、屬性描述符的完整選項、常見使用場景等,感興趣的朋友跟隨小編一起看看吧
    2025-01-01
  • JavaScript 組件之旅(三):用 Ant 構(gòu)建組件

    JavaScript 組件之旅(三):用 Ant 構(gòu)建組件

    我們走到哪兒了?前兩期思考了太多東西,你是否已有倦意?別擔(dān)心,本期的話題很輕松,你只需要簡單了解一些語法,寫幾行配置,就能驅(qū)使系統(tǒng)按你預(yù)設(shè)的方式自動完成一些工作。
    2009-10-10
  • 使用html2canvas截圖不全問題的解決辦法

    使用html2canvas截圖不全問題的解決辦法

    這篇文章主要給大家介紹了關(guān)于使用html2canvas截圖不全問題的解決辦法,最近在項目中遇到一個需求,需要提供網(wǎng)頁截圖的功能,這里將遇到的問題分享給大家,需要的朋友可以參考下
    2023-07-07
  • javascript中自定義對象的屬性方法分享

    javascript中自定義對象的屬性方法分享

    這篇文章介紹了在javascript中自定義對象的屬性方法,有需要的朋友可以參考一下
    2013-07-07
  • BootStrap表單控件之復(fù)選框checkbox和單選擇按鈕radio

    BootStrap表單控件之復(fù)選框checkbox和單選擇按鈕radio

    這篇文章主要介紹了BootStrap表單控件之復(fù)選框checkbox和單選擇按鈕radio的相關(guān)資料,需要的朋友可以參考下
    2017-05-05
  • JavaScript阻止事件冒泡和默認(rèn)行為的方法舉例

    JavaScript阻止事件冒泡和默認(rèn)行為的方法舉例

    JavaScript事件的默認(rèn)行為指瀏覽器自動執(zhí)行的操作,如鏈接跳轉(zhuǎn)或表單提交,阻止這些行為可以使用event.preventDefault()、return?false或event.returnValue屬性,event.stopPropagation()用于阻止事件傳播,不直接阻止默認(rèn)行為,需要的朋友可以參考下
    2024-10-10
  • javascript數(shù)組常見操作方法實例總結(jié)【連接、添加、刪除、去重、排序等】

    javascript數(shù)組常見操作方法實例總結(jié)【連接、添加、刪除、去重、排序等】

    這篇文章主要介紹了javascript數(shù)組常見操作方法,結(jié)合實例形式總結(jié)分析了javascript數(shù)組的連接、添加、刪除、去重、排序等操作,代碼注釋附帶較為詳細(xì)的說明,需要的朋友可以參考下
    2019-06-06
  • JavaScript中的事件循環(huán)機制及其運行原理

    JavaScript中的事件循環(huán)機制及其運行原理

    JavaScript中的事件循環(huán)機制是一種異步處理機制,通過維護(hù)事件隊列和消息隊列,實現(xiàn)任務(wù)的分發(fā)和執(zhí)行。事件循環(huán)機制由主線程和任務(wù)隊列構(gòu)成,主線程運行完當(dāng)前任務(wù)后會檢查任務(wù)隊列中是否有待執(zhí)行的任務(wù),如有則執(zhí)行,否則等待
    2023-04-04

最新評論