仵航说 vue iframe嵌套外部网页 仵老大

    下午经理让我在客户服务平台创建一个新的路由,把我们之前写的报表工具嵌套进去,之前的是通过ip访问的,讨论了一会决定用神器 iframe,直接嵌套进去,之前也写过,代码这个东西,CV才是精髓,去某度看了一下,随后开始操作

    首先创建好了路由的权限,让他在页面也可以进行点点点的操作,之后创建vue页面

去页面看看


     成功出现,下面看一下我之前开发的页面的样子,记住这个ip,这个页面非常完美啊,有条件查询,有分页,有......


然后直接使用iframe嵌套进去

嵌套进去之后,属实有点怪


先不管UI了,最后再调,我觉得是我引入页面的问题,我待会去设置一下应该就是可以了,分享一下代码

<template>

  <div>

    <iframe src="外部网页url" id="mobsf" frameborder="0" style="position:absolute;"></iframe>

  </div>

</template>

<script>

  export default {

    data () {

      return {

      }

    },

    mounted(){

      /**

      * iframe-宽高自适应显示

      */

      function changeMobsfIframe(){

        const mobsf = document.getElementById('mobsf');

        const deviceWidth = document.body.clientWidth;

        const deviceHeight = document.body.clientHeight;

        mobsf.style.width = (Number(deviceWidth)-220) + 'px'; //数字是页面布局宽度差值

        mobsf.style.height = (Number(deviceHeight)-80) + 'px'; //数字是页面布局高度差

      }

      changeMobsfIframe()

      window.onresize = function(){

        changeMobsfIframe()

      }

    },

  }

</script>

现在要解决的是url的问题了,在公司肯定不会让你每次引入页面都把url写死的,所以我们来解决他


找到你们项目中负责控制url的文件,我的是这个,所以我就在这里直接规定


搞了一晚上,一直NaN原来这个.env文件是有点东西的给你们普及一下

.env 全局默认配置文件,不论什么环境都会加载合并

.env.development 开发环境下的配置文件

.env.production 生产环境下的配置文件

注意:属性名必须以VUE_APP_开头,比如VUE_APP_XXX

.env:

其中最重要的是,.env文件数据配置文件,修改完之后一定要重启,切记


上一下代码

说一下引入的思路,先引入hrCloudCommon里面的js

然后初始化设置的时候定义一个方法,在methods里面给路径赋值

通过data的return到上面的template里面

随后iframe的src记得加上:

:的意思就是给这个对象赋Vue属性

<template>

  <div>

<!--    <iframe :src="ReportUrl1" id="mobsf" frameborder="0" style="position:absolute;"></iframe>-->

    <iframe :src="ReportUrl1" style="width: 100%;height: 100%;min-height: 600px"></iframe>

  </div>

</template>

<script>

  import Report from '@/api/common/hrcloudCommon';

    export default {

        name: "Report",

      data () {

        return {

          ReportUrl1:''

        }

      },

      mounted(){

          this.showReport();

        /**

        * iframe-宽高自适应显示

        */

        function changeMobsfIframe(){

          const mobsf = document.getElementById('mobsf');

          const deviceWidth = document.body.clientWidth;

          const deviceHeight = document.body.clientHeight;

          mobsf.style.width = (Number(deviceWidth)-220) + 'px'; //数字是页面布局宽度差值

          mobsf.style.height = (Number(deviceHeight)-80) + 'px'; //数字是页面布局高度差

        }

        changeMobsfIframe()

        window.onresize = function(){

          changeMobsfIframe()

        }

      },

      methods:{

          showReport(){

            let ReportUrl = Report.Report_Cli_URL+"reportTools/cusMain";

            // let ReportUrl = Report.Report_Cli_URL

            console.log("ReportUrl",ReportUrl)

            // let ReportUrl = 'http://192.168.251.62:9093'

            let HRUrl = Report.HRCLOUD_URL

            this.ReportUrl1 = ReportUrl

            //console.log("ReportUrl",ReportUrl)

            //alert("1")

          }

      }

    }

</script>

<style scoped>

</style>

最后就嵌套成功了


事情并没有结束,经理说不要这个页面,要根据右上角的ciic188的id进行查询,判断,这可难住我了,先写根据id拼接页面吧,其他的先不管

showReport(){

  let ReportId = '4417';

  let ReportUrl = Report.Report_Cli_URL+"reportTools/newreportList/"+ReportId;

  console.log("ReportUrl",ReportUrl)

  this.ReportUrl1 = ReportUrl

}

可以看到直接规定一个 ReportID 然后根据经理给出的路径一拼接就可以了

但没说这个ReportId是啥,经理让我自己找,这就有点麻烦了,下次给大家分享一个好东西

先分享一下成功的图片


但是这个ReportId是死的所以需要确定id,也就是Id,这里我找到之后用sessionStorage把id存进去了,然后在这个id取出就可以了大致代码是这样

showReport(){

  let ReportId =  sessionStorage.getItem("cusId")

  console.log("ReportId",ReportId)

  let ReportUrl = Report.Report_Cli_URL+"reportTools/newreportList/"+ReportId;

  console.log("ReportUrl",ReportUrl)

  this.ReportUrl1 = ReportUrl

  if (ReportId != ""){

    this.$message.success("查询成功")

  }else {

    this.$message.warning("暂无数据")

  }

}

以上就是Vue使用iframe前台外部页面的详细内容,更多请关注我分享的其它相关文章!

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 199,440评论 5 467
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 83,814评论 2 376
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 146,427评论 0 330
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 53,710评论 1 270
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 62,625评论 5 359
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,014评论 1 275
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,511评论 3 390
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,162评论 0 254
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,311评论 1 294
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,262评论 2 317
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,278评论 1 328
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 32,989评论 3 316
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,583评论 3 303
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,664评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,904评论 1 255
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,274评论 2 345
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 41,856评论 2 339

推荐阅读更多精彩内容