日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁(yè)技術(shù)文章
文章詳情頁(yè)

開發(fā)一個(gè)封裝iframe的vue組件

瀏覽:29日期:2022-10-01 10:18:42

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

組件的好處,一是可以加強(qiáng)復(fù)用;二是能夠?qū)⑻囟üδ芊庋b,利于調(diào)用;三是由于職責(zé)分明,組件高內(nèi)聚,組件間低耦合,利于系統(tǒng)功能的優(yōu)化、擴(kuò)展和維護(hù)。好處多多。

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

一、組件介紹

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

二、組件內(nèi)部結(jié)構(gòu)及邏輯1、代碼組織結(jié)構(gòu)

開發(fā)一個(gè)封裝iframe的vue組件

2、地圖組件

Map.vue

<template> <div class='map-container'> <!-- 承載地圖頁(yè)面 --> <iframe :src='http://m.b3g6.com/bcjs/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’],//純測(cè)試,沒啥用,對(duì)應(yīng)<Map ref='map' size='100'></Map> data() { return {src: ’’,//地圖頁(yè)面地址isLoaded: false,//地圖頁(yè)面是否加載完畢iMap: null,//地圖頁(yè)面暴露出來的,供外部訪問的對(duì)象require: null//arcgis的require函數(shù),用于引用自定義插件。我們過去寫了不少自定義的地圖插件 } }, created() { this.src = config.publicPath + ’map.html’ }, mounted() { //監(jiān)聽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>

有關(guān)組件的結(jié)構(gòu),比如

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

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

開發(fā)一個(gè)封裝iframe的vue組件

像這類簡(jiǎn)單的介紹,在網(wǎng)上怎么也搜不到。vue的中文站點(diǎn),陳舊,內(nèi)容支離破碎,對(duì)初學(xué)者極不友好,加重了學(xué)習(xí)的成本。

三、iframe接口

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

iframe承載的地圖頁(yè)面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頁(yè)面發(fā)送加載完畢信號(hào) window.parent.postMessage({ cmd: ’mapIsReady’, params: { success: true, data: true } }, ’*’); /* end of 外部接口 */ });</script>

地圖組件Map.vue對(duì)應(yīng)iframe部分,詳見一.2中的代碼

export default {。。。 mounted() { //監(jiān)聽iframe的消息 window.addEventListener(’message’, this.handleMessage) //獲得iframe的window對(duì)象 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是一個(gè)組件,它要跟它所在的組件或頁(yè)面進(jìn)行通信。

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

命令組件的按鈕點(diǎn)擊后,發(fā)射信息到容器頁(yè)面,然后容器頁(yè)面調(diào)用地圖組件的方法。

測(cè)試頁(yè)面Home.vue

<template> <div id='app1'> <div id='map-container'> <div>地圖組件</div> <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){//加載衛(wèi)星云圖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'>衛(wèi)星云圖</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>

注意命令組件發(fā)射消息中指定的方法,在容器頁(yè)面中都有相關(guān)的屬性與之對(duì)應(yīng):

命令組件loadCloud(){ let data = ...; this.$emit('loadCloud', data);},容器頁(yè)面<Layer @loadLayer='loadLayer' @loadCloud='loadCloud' @clear='clearMap'></Layer>五、運(yùn)行結(jié)果

開發(fā)一個(gè)封裝iframe的vue組件

六、總結(jié)

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

以上就是開發(fā)一個(gè)封裝iframe的vue組件的詳細(xì)內(nèi)容,更多關(guān)于封裝iframe的vue組件的資料請(qǐng)關(guān)注好吧啦網(wǎng)其它相關(guān)文章!

標(biāo)簽: Vue
相關(guān)文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
999精品色在线播放| 欧美日韩精品免费观看视频完整| 超碰在线99| 日本在线啊啊| 免费污视频在线一区| 久久久精品久久久久久96| 五月天av在线| 香蕉久久99| 蜜桃久久av一区| 国产伦精品一区二区三区视频| 亚洲涩涩av| 午夜在线一区| 亚洲精选91| 国产精品sm| 不卡一二三区| 激情91久久| 亚洲欧洲日韩精品在线| 日本不卡中文字幕| 国产精品视频一区二区三区 | 久久性天堂网| 亚洲一二av| 美女av一区| 国产综合欧美| 日韩不卡手机在线v区| 午夜电影一区| 国产在线看片免费视频在线观看| 91精品推荐| 日韩和欧美一区二区三区| 国产成人精品免费视| 在线视频日韩| 麻豆国产91在线播放| 亚洲二区三区不卡| 国产伦理久久久久久妇女| 成人久久一区| 91精品日本| 欧美精品九九| 97欧美在线视频| 日韩精品免费视频一区二区三区| 久久久久久自在自线| 精品在线播放| sm捆绑调教国产免费网站在线观看| 男女性色大片免费观看一区二区 | 久久av资源| 中文无码日韩欧| 日韩精品午夜| 国产精品一区二区三区美女| 影视先锋久久| 国产一区福利| 日韩国产在线观看| 亚洲无线一线二线三线区别av| 日韩福利在线观看| 五月天久久网站| 国产videos久久| 国产伦精品一区二区三区千人斩 | 98精品视频| 国产精品久久久久久久免费观看| 久久国内精品视频| 中文字幕日韩欧美精品高清在线| 精品一区毛片| 一区在线免费观看| 免费观看久久av| 国产99亚洲| 一区久久精品| 欧美/亚洲一区| 久久中文字幕av| 黄色欧美日韩| 羞羞答答国产精品www一本| 日韩一级欧洲| 亚洲一区二区三区四区电影| 另类av一区二区| 亚洲激情另类| 亚洲区国产区| 国产精品最新自拍| 精品国产不卡| 欧美香蕉视频| 亚洲男女自偷自拍| 亚洲精品欧美| 美女久久久久久| 精品三级国产| 久久久久久久久丰满| 美女久久久久| 日韩激情精品| 成人午夜精品| 日韩午夜精品| 欧美久久久网站| 亚洲va中文在线播放免费| 久久久成人网| 欧美视频二区| 欧美日韩在线二区| 亚洲精品高潮| 吉吉日韩欧美| 丝袜美腿高跟呻吟高潮一区| 日韩激情综合| 伊人久久视频| 在线看片日韩| 中文字幕在线看片| 亚洲免费在线| 欧美一区久久久| 日韩不卡一二三区| 国内精品福利| 久久精品五月| 亚洲一区二区小说| 欧美日韩一二三四| 欧美国产先锋| 亚洲人亚洲人色久| 天堂网av成人| 久久这里只有精品一区二区| 美美哒免费高清在线观看视频一区二区| 国产日韩高清一区二区三区在线 | 99热精品在线观看| 欧美亚洲三区| 日韩中文字幕91| 欧美色图一区| 高清久久一区| 久久av影视| 国产亚洲精品美女久久久久久久久久| 99精品网站| 麻豆一区二区在线| 国产精品一区二区av交换 | 亚洲国内欧美| 欧美日韩免费观看视频| 欧美成a人片免费观看久久五月天| 免费观看在线色综合| 夜夜精品视频| 麻豆91精品| 免费久久99精品国产| 性一交一乱一区二区洋洋av| 亚洲一本视频| 午夜免费一区| 九一成人免费视频| 欧美日韩国产在线一区| 天堂中文在线播放| www成人在线视频| 国产在线欧美| 免播放器亚洲| 日韩精品一区二区三区av| 日韩福利在线观看| 免费日韩成人| 亚洲黄色免费av| 日韩视频二区| 亚洲乱码一区| 国产精品18| 亚洲欧洲美洲av| 欧美日韩精品一本二本三本| 亚洲精选久久| 美女国产精品久久久| 国产在线一区不卡| 香蕉国产精品| 日本va欧美va精品| 国产一区精品福利| 日韩视频久久| 国产精品对白久久久久粗| 精品三级在线| 蜜臀久久久久久久| 欧美激情麻豆| 影院欧美亚洲| 国产精品久久久久久模特| 欧美成a人国产精品高清乱码在线观看片在线观看久 | 日韩一区精品| 国产一区二区三区黄网站| 99精品在线观看| 国产精品一区二区三区www| 秋霞影视一区二区三区| 亚洲专区在线| 久久影院一区二区三区| 亚洲一区二区毛片| 久久97视频| 亚洲精品看片| 亚洲国产一区二区三区在线播放| 国产精品调教视频| 老鸭窝亚洲一区二区三区| 激情黄产视频在线免费观看| 久久亚洲二区| 久久国产中文字幕| 国产福利一区二区三区在线播放| 好看的av在线不卡观看| 国产一区国产二区国产三区| 日日夜夜免费精品视频| av资源亚洲| 日本欧美一区二区| 亚洲女同一区| 亚洲黄色免费av| 久久精品国产亚洲aⅴ| 午夜亚洲福利| 免费看黄色91| 亚洲涩涩av| 日韩精品一二三四| 免费日韩av片| 久久av一区| 蜜桃久久久久久| 日韩视频久久| 亚洲少妇自拍| 久久xxxx精品视频| 亚洲大全视频| 欧洲毛片在线视频免费观看| 日韩专区精品| 免费不卡中文字幕在线| 黄色欧美日韩| 日本伊人久久| 国产欧美日韩精品一区二区免费|