电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

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

開發一個封裝iframe的vue組件

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

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='http://www.hdgsjgj.cn/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’],//純測試,沒啥用,對應<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 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組件的資料請關注好吧啦網其它相關文章!

標簽: Vue
相關文章:
主站蜘蛛池模板: 纸箱抗压机,拉力机,脂肪测定仪,定氮仪-山东德瑞克仪器有限公司 | 披萨石_披萨盘_电器家电隔热绵加工定制_佛山市南海区西樵南方综合保温材料厂 | 开锐教育-学历提升-职称评定-职业资格培训-积分入户 | 代写标书-专业代做标书-商业计划书代写「深圳卓越创兴公司」 | 板式换网器_柱式换网器_自动换网器-郑州海科熔体泵有限公司 | 闸阀_截止阀_止回阀「生产厂家」-上海卡比阀门有限公司 | 煤机配件厂家_刮板机配件_链轮轴组_河南双志机械设备有限公司 | 无味渗透剂,泡沫抑尘剂,烷基糖苷-威海威能化工有限公司 | 西宁装修_西宁装修公司-西宁业之峰装饰-青海业之峰墅级装饰设计公司【官网】 | 移动厕所租赁|移动卫生间|上海移动厕所租赁-家瑞租赁 | 丹佛斯变频器-Danfoss战略代理经销商-上海津信变频器有限公司 | 水厂自动化-水厂控制系统-泵站自动化|控制系统-闸门自动化控制-济南华通中控科技有限公司 | 一体化污水处理设备_生活污水处理设备_全自动加药装置厂家-明基环保 | 上海道勤塑化有限公司 | 日本东丽膜_反渗透膜_RO膜价格_超滤膜_纳滤膜-北京东丽阳光官网 日本细胞免疫疗法_肿瘤免疫治疗_NK细胞疗法 - 免疫密码 | 手板-手板模型-手板厂-手板加工-生产厂家,[东莞创域模型] | 屏蔽泵厂家,化工屏蔽泵_维修-淄博泵业 | 培训一点通 - 合肥驾校 - 合肥新亚驾校 - 合肥八一驾校 | 隔离变压器-伺服变压器--输入输出电抗器-深圳市德而沃电气有限公司 | 武汉创亿电气设备有限公司_电力检测设备生产厂家 | 胶辊硫化罐_胶鞋硫化罐_硫化罐厂家-山东鑫泰鑫智能装备有限公司 意大利Frascold/富士豪压缩机_富士豪半封闭压缩机_富士豪活塞压缩机_富士豪螺杆压缩机 | 电表箱-浙江迈峰电力设备有限公司-电表箱专业制造商 | 米顿罗计量泵(科普)——韬铭机械 | 塑胶跑道_学校塑胶跑道_塑胶球场_运动场材料厂家_中国塑胶跑道十大生产厂家_混合型塑胶跑道_透气型塑胶跑道-广东绿晨体育设施有限公司 | 股票入门基础知识_股票知识_股票投资大师_格雷厄姆网 | 多米诺-多米诺世界纪录团队-多米诺世界-多米诺团队培训-多米诺公关活动-多米诺创意广告-多米诺大型表演-多米诺专业赛事 | 糖衣机,除尘式糖衣机,全自动糖衣机,泰州市长江制药机械有限公司 体感VRAR全息沉浸式3D投影多媒体展厅展会游戏互动-万展互动 | 热闷罐-高温罐-钢渣热闷罐-山东鑫泰鑫智能热闷罐厂家 | 电液推杆生产厂家|电动推杆|液压推杆-扬州唯升机械有限公司 | 马尔表面粗糙度仪-MAHR-T500Hommel-Mitutoyo粗糙度仪-笃挚仪器 | 天津云仓-天津仓储物流-天津云仓一件代发-顺东云仓 | 小型高低温循环试验箱-可程式高低温湿热交变试验箱-东莞市拓德环境测试设备有限公司 | 德州网站制作 - 网站建设设计 - seo排名优化 -「两山建站」 | 气弹簧定制-气动杆-可控气弹簧-不锈钢阻尼器-工业气弹簧-可调节气弹簧厂家-常州巨腾气弹簧供应商 | 气动|电动调节阀|球阀|蝶阀-自力式调节阀-上海渠工阀门管道工程有限公司 | 水厂自动化|污水处理中控系统|水利信息化|智慧水务|智慧农业-山东德艾自动化科技有限公司 | 国际船舶网 - 船厂、船舶、造船、船舶设备、航运及海洋工程等相关行业综合信息平台 | 合金ICP光谱仪(磁性材料,工业废水)-百科 | 基本型顶空进样器-全自动热脱附解吸仪价格-AutoHS全模式-成都科林分析技术有限公司 | 合肥白癜风医院_合肥治疗白癜风医院_合肥看白癜风医院哪家好_合肥华研白癜风医院 | 雷达液位计_超声波风速风向仪_雨量传感器_辐射传感器-山东风途物联网 |