一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務器之家:專注于服務器技術及軟件下載分享
分類導航

node.js|vue.js|jquery|angularjs|React|json|js教程|

服務器之家 - 編程語言 - JavaScript - vue.js - 開發一個封裝iframe的vue組件

開發一個封裝iframe的vue組件

2022-02-21 16:51左直拳 vue.js

這篇文章主要介紹了開發一個封裝iframe的vue組件,幫助大家更好的理解和學習使用vue框架,感興趣的朋友可以了解下

VUE的基本組成單元,我看應該是組件。用VUE開發前端項目,就是開發一個個組件,然后搭積木一樣,將項目搭建出來。組件包含在頁面,或者是更大的組件里面。在這里,組件與頁面的界限,好像并不明顯。事實上,對于單頁應用,只有一個頁面。

組件的好處,一是可以加強復用;二是能夠將特定功能封裝,利于調用;三是由于職責分明,組件高內聚,組件間低耦合,利于系統功能的優化、擴展和維護。好處多多。

開發組件,主要有2部分內容:
1、組件內部邏輯
2、外部接口
由于我這兩天弄的組件,里面包含有一個<iframe>,那么還有一部分工作內容:
3、iframe接口

一、組件介紹

這是一個地圖插件。功能是展示地圖,以及接受外部命令,加載圖層、繪制圖形等相關操作。地圖采用arcgis for js實現。由于我們過去開發的項目,地圖操作有一些積累,不過并沒有前后端分離,沒有采用VUE或REACT,還是傳統的WEB頁面。因為時間緊,也想直接復用以前的成果,于是考慮用<iframe>承載地圖頁面,封裝在VUE組件里,由組件對接外部命令并與iframe里的地圖頁面交互。

二、組件內部結構及邏輯

1、代碼組織結構

開發一個封裝iframe的vue組件

2、地圖組件

Map.vue

<template>
 <div class="map-container">
 	<!-- 承載地圖頁面 -->
  <iframe :src="src" ref="iframe" @load="iframeLoad"></iframe>
 </div>
</template>

<!-- Add "scoped" attribute to limit CSS to this component only -->
<style scoped="scoped">
 .map-container iframe{
  width: 100%;
  height: 100%;
  border: none;  
 }
</style>

<script>
 import config from "../../vue.config"//里面有路徑信息
 
 let iframeWin = null;//私有變量
 
 export default {
  props:["size"],//純測試,沒啥用,對應<Map id="map" ref="map" size="100"></Map>
  data() {
   return {
    src: "",//地圖頁面地址
    isLoaded: false,//地圖頁面是否加載完畢
    iMap: null,//地圖頁面暴露出來的,供外部訪問的對象
    require: null//arcgis的require函數,用于引用自定義插件。我們過去寫了不少自定義的地圖插件
   }
  },
  created() {
   this.src = config.publicPath + "map.html"
  },
  mounted() {
  	//監聽iframe的消息
   window.addEventListener("message", this.handleMessage)
   iframeWin = this.$refs.iframe.contentWindow
  },
  methods: {
   iframeLoad() {
    this.isLoaded = true;
    window.console.log("map is ready")
   },   
   async handleMessage() {//接收來自iframe的消息
    this.require = iframeWin.require;
    this.iMap = iframeWin.iMap;
   },
   loadLayer(nodes,servers){
    this.iMap.layerHandler.load(nodes,servers);
   },
   isReady(){
    return this.isLoaded;
   }
  }
 }
</script>

有關組件的結構,比如

export default {
 props:,//標記里的屬性
 data() {//公共變量
 },
 created() {//加載時?
 },
 mounted() {//加載完畢時
 },
 methods: {//公共方法
 }
}

export代表了這是對外。所以里面的屬性、變量、方法,都可以被外部訪問。如果想私有,應該在export之外定義。如本例:

開發一個封裝iframe的vue組件

像這類簡單的介紹,在網上怎么也搜不到。vue的中文站點,陳舊,內容支離破碎,對初學者極不友好,加重了學習的成本。

三、iframe接口

組件Map.vue與里面的iframe是怎么通信的呢?
通過系統消息和直接訪問iframe的對象。直接訪問iframe里的對象有個前提,就是不能跨域。

iframe承載的地圖頁面map.html

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/strict.dtd">
<html>
 <head>
		...
 </head>
 <body>
  <div id="map"></div>
		...
  </div>  

 </body>
</html>
<script src="http://192.168.0.200/pubzy211/arcgis_js_api/3.19/init.js"></script>
<script type="text/javascript">
 var iMap = {}; //外部引用接口

 require([
  "esri/config",
  "esri/map",
  "esri/geometry/Extent",
  "esri/SpatialReference",

  "layerlib/LtLayer",

  "dojo/dom",
  "dojo/_base/array",
  "dojo/parser",
  "dojo/domReady!"
 ], function(
  esriConfig,
  Map,
  Extent,
  SpatialReference,

  LtLayer,
  dom,
  arrayUtils,
  parser
 ) {
  //map
  var map = ...

  /* 外部接口 */
  iMap = {
   map: map,
   legend: legend,
   home: home,
   tipDialog: tipDialog,
   toggle: toggle,
   overviewMap: overviewMap
  };
  iMap.drawHandler = ...
  iMap.layerHandler = ...;
  iMap.centerAt = ...;
  iMap.clear = ...;
  iMap.restoreView = ...;

  // 向父vue頁面發送加載完畢信號
  window.parent.postMessage({
   cmd: "mapIsReady",
   params: {
    success: true,
    data: true
   }
  }, "*");
  /* end of 外部接口 */

 });
</script>

地圖組件Map.vue對應iframe部分,詳見一.2中的代碼

export default {
		。。。
  mounted() {
	  //監聽iframe的消息
   window.addEventListener("message", this.handleMessage)
   //獲得iframe的window對象
   iframeWin = this.$refs.iframe.contentWindow
  },
  methods: {
   iframeLoad() {
    this.isLoaded = true;
    window.console.log("map is ready")
   },   
   async handleMessage() {//接收來自iframe的消息
    this.require = iframeWin.require;
    this.iMap = iframeWin.iMap;
   },
   loadLayer(nodes,servers){
   	//加載圖層
    this.iMap.layerHandler.load(nodes,servers);
   }
  }
 }

四、外部接口

Map.vue是一個組件,它要跟它所在的組件或頁面進行通信。

現在,Map.vue放在了一個容器頁面Home.vue(即測試頁面)里,里面還有一個命令組件Layer.vue。點擊命令組件里的按鈕,地圖要做出相應的響應。其中的原理如下:

命令組件的按鈕點擊后,發射信息到容器頁面,然后容器頁面調用地圖組件的方法。

測試頁面Home.vue

<template>
 <div id="app1">
  <div id="map-container">
   <div>地圖組件</div>
   <Map id="map" ref="map" size="100"></Map>
  </div>
  <div id="layer-container">
   <div>其他組件</div>
   <Layer @loadLayer="loadLayer" @loadCloud="loadCloud" @clear="clearMap"></Layer>
  </div>
 </div>
</template>

<script>
 import Map from "../components/Map.vue"
 import Layer from "../components/Layer.vue"

 export default {
  name: "App",
  components: {
   Map,
   Layer
  },
  methods:{
   loadLayer(nodes,servers){//加載圖層
    let map = this.$refs.map;
    map.loadLayer(nodes,servers);
   },
   loadCloud(data){//加載衛星云圖
    let map = this.$refs.map;
    map.require(["drawlib/Cloud"], function (Cloud) {
     let iMap = map.iMap;
     let cloudId = "cloud";
     let cloud = new Cloud(iMap.map);
     iMap.drawHandler.push(cloudId, cloud);
     cloud.draw(data,cloudId);
    });
   },
   clearMap(){//清除
    let map = this.$refs.map;
    map.iMap.clear();
   }
  }
 }
</script>

<style>
。。。
</style>

命令組件Layer.vue

<template>
 <div class="layer-container">
  <button @click="loadLayer">加載圖層</button>
  <button @click="loadCloud">衛星云圖</button>
  <button @click="clear">清除</button>
 </div>
</template>

<script>
 export default {
  methods: {
   loadLayer() {
    let nodes = ...
    let servers = ...
    this.$emit("loadLayer", nodes,servers)
   },
   loadCloud(){
    let data = ...;
    this.$emit("loadCloud", data);
   },
   clear(){
    this.$emit("clear");
   }
  },
 }
</script>

<style scoped="scoped">
。。。
</style>

注意命令組件發射消息中指定的方法,在容器頁面中都有相關的屬性與之對應:

命令組件
loadCloud(){
 let data = ...;
 this.$emit("loadCloud", data);
},

容器頁面
<Layer @loadLayer="loadLayer" @loadCloud="loadCloud" @clear="clearMap"></Layer>

五、運行結果

開發一個封裝iframe的vue組件

六、總結

其他組件要與地圖組件交互,中間要通過容器頁面,其他組件與地圖組件并沒有直接交互。這其實是一種命令模式。好處是其他組件和地圖組件解耦,沒有耦合在一起,意味著互不影響。這有利于地圖組件本身的擴展和優化。缺點的話,每個東東都要通過容器頁面轉發,容器頁面代碼可能會有冗余,有些方法根本就是個傳聲筒,給人的感覺是重重復復的寫,意義不太大。

以上就是開發一個封裝iframe的vue組件的詳細內容,更多關于封裝iframe的vue組件的資料請關注服務器之家其它相關文章!

原文鏈接:https://blog.csdn.net/leftfist/article/details/115206838

延伸 · 閱讀

精彩推薦
  • vue.jsVue項目中實現帶參跳轉功能

    Vue項目中實現帶參跳轉功能

    最近做了一個手機端系統,其中遇到了父頁面需要攜帶參數跳轉至子頁面的問題,現已解決,下面分享一下實現過程,感興趣的朋友一起看看吧...

    YiluRen丶4302022-03-03
  • vue.jsVue多選列表組件深入詳解

    Vue多選列表組件深入詳解

    這篇文章主要介紹了Vue多選列表組件深入詳解,這個是vue的基本組件,有需要的同學可以研究下...

    yukiwu6752022-01-25
  • vue.jsVue2.x-使用防抖以及節流的示例

    Vue2.x-使用防抖以及節流的示例

    這篇文章主要介紹了Vue2.x-使用防抖以及節流的示例,幫助大家更好的理解和學習使用vue框架,感興趣的朋友可以了解下...

    Kyara6372022-01-25
  • vue.js詳解vue 表單綁定與組件

    詳解vue 表單綁定與組件

    這篇文章主要介紹了vue 表單綁定與組件的相關資料,幫助大家更好的理解和學習使用vue框架,感興趣的朋友可以了解下...

    Latteitcjz6432022-02-12
  • vue.js用vite搭建vue3應用的實現方法

    用vite搭建vue3應用的實現方法

    這篇文章主要介紹了用vite搭建vue3應用的實現方法,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下...

    Asiter7912022-01-22
  • vue.jsVue2.x 項目性能優化之代碼優化的實現

    Vue2.x 項目性能優化之代碼優化的實現

    這篇文章主要介紹了Vue2.x 項目性能優化之代碼優化的實現,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋...

    優小U9632022-02-21
  • vue.js梳理一下vue中的生命周期

    梳理一下vue中的生命周期

    看過很多人講vue的生命周期,但總是被繞的云里霧里,尤其是自學的同學,可能js的基礎也不是太牢固,聽起來更是吃力,那我就已個人之淺見,以大白話...

    CRMEB技術團隊7992021-12-22
  • vue.jsVue中引入svg圖標的兩種方式

    Vue中引入svg圖標的兩種方式

    這篇文章主要給大家介紹了關于Vue中引入svg圖標的兩種方式,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的...

    十里不故夢10222021-12-31
主站蜘蛛池模板: 兽皇videos日本另类 | 91高清在线视频 | ts人妖系列在线专区 | 亚洲xxxxxhd奶水女人 | 国产二区视频 | juy_661佐佐木明希在线播放 | 楚乔传第二部免费完整 | 亚洲人影院 | 国产精品视频二区不卡 | 人皮高跟鞋在线观看 | 国产成人yy精品1024在线 | 美女的让男人桶爽免费看 | 欧美亚洲另类在线观看 | 顶级尤物极品女神福利视频 | 午夜爱 | 黄瓜视频导航 | 日韩免费一级毛片 | 王淑兰李思雨李铁柱乡村小说免费 | 亚洲精品国产SUV | 日韩理论片在线看免费观看 | 国产肥老上视频 | 欧美胖逼 | 日本又黄又裸一级大黄裸片 | 亚洲精品国偷拍自产在线观看蜜臀 | 亚洲国产在线视频中文字 | 久久综合狠狠综合久久综合88 | 午夜成私人影院在线观看 | ai换脸明星专区在线观看 | 免费在线观看网址大全 | 免费看又黄又爽又猛的视频软件- | 日本一区三区 | 6个老师的尿奴 | 三级aa久久| 俄罗斯极品h在线 | 精品一区二区视频 | 青青草国产免费国产是公开 | 深夜在线网址 | 513热点网深夜影院影院诶 | 蜜桃成熟3在线观看 | 国产91精品久久久久久久 | 国产成人综合网亚洲欧美在线 |