IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> JavaScript知识库 -> vue项目关于iframe嵌套的相关问题总结(二) -> 正文阅读

[JavaScript知识库]vue项目关于iframe嵌套的相关问题总结(二)

vue项目关于iframe嵌套的相关问题总结(二)

  • 需求:
    1. A系统某个页面(父)需要 嵌套 B系统(子)某个页面
    2. 利用iframe嵌套的时候需要从父页面传参到子页面
    3. 这里有两种解决方案:src拼参或者利用postMessage传参
  • 方案一: src拼参

    A系统父页面(index.vue): 代码如下

    <template>
        <div>
            <iframe name="myiframe"  id="myrame"  :src="url"    width="100%"  height="100vh"></iframe>
        </div>
    </template>
    <script>
    export default {
      data(){
        return{
          url:'', 
          userId:"12345678",
          userName:"百度",
        }
      },
      mounted(){
      	// 这里采用url拼接传参
        this.url="http://127.0.0.1:5500/index.html?userId="+this.userId+'&userName='+this.userName 
      },
    }
    </script>
    <style scoped>
    #myiframe{
        width: 100%;
        height: 100vh;
    }
    </style>
    

    B系统子页面(index.html):代码如下:

    <script type="text/javascript">
    	console.log('11,loca-------',location.href) // location.href可以获得当前页面URL;
    	// 处理参数
        if(location.href.indexOf("?")>-1) {
            var params1 = location.href.substr(location.href.indexOf("?")+1).split("&");
            var jsj = {}
            for (var i=0;i<params1.length;i++){
                var kv = params1[i].split("=");
                var key = kv[0];
                var value = kv[1];
                jsj[key]=value
            }
            console.log(23,jsj)
        }
    </script>
    

    控制台输出结果如图:
    在这里插入图片描述

    注意:这里我们看到输出的userName属性乱码了!

    👿 这是因为在用iframe的src拼接属性传参的时候,如果参数中有中文,就会出现乱码的问题

    👿 我们传参,肯定是需要用参呀,如果参数乱码,那是不行的,所以又给自己挖了一个坑。。。

    那出现问题就得解决问题(先不要考虑postMessage)

    ?? 这里我们的思路是既然乱码,那是不是可以解码呀??? so …

    ?? 前端在传参的同事先编码利用 encodeURI("包含中文的串")

    ?? 然后后端需要解码利用:java.net.URLDecoder.decode("需要解码的串","utf-8");

    😃 (我没有实验,只是在网上查阅了相关资料得到的总结哈哈哈 😃)但是,如果把后端也带入这个需求中,就明显有点麻烦,所以此方案行不通,怎么能麻烦人家后端给你解码呢哈哈哈。。。。那当然自己解决啦 。。。。

    这里就可以考虑postMessage啦

  • 方案二 :postMessage传参:

    postMessage 是 html5 引入window的API,postMessage()方法允许来自不同源的脚本采用异步方式进行有效的通信,可以实现跨文本文档多窗口跨域消息传递多用于窗口间数据通信,这也使它成为跨域通信的一种有效的解决方案。

    语法:otherWindow.postMessage(message, targetOrigin, [transfer]);

    😃 otherWindow:其他窗口的一个引用,比如iframe的contentWindow属性、执行window.open返回的窗口对象、或者是命名过或数值索引的window.frames

    😃 message:将要发送到其他 window的数据。

    😃 targetOrigin:通过窗口的origin属性来指定哪些窗口能接收到消息事件,其值可以是字符串"*"(表示无限制)或者一个URI

    A系统父页面(index.vue): 代码如下

    <template>
        <div>
            <iframe name="myiframe" ref="refdiv" id="myrame"  :src="url"  frameborder="0" align="middle"  width="100%"  height="1000px"></iframe>
        </div>
    </template>
    <script>
    export default {
      data(){
        return{
          url:'',
          userId:"12345678",
          userName:"百度",
        }
      },
      mounted(){
        this.url="http://127.0.0.1:5500/index.html"
        let _this = this // 因为window.onload获取不到vue示例,所以这里先将示例赋值给_this
        window.onload=function(){ //页面初始化加载完成就需要传参,所以这里需要在window.onload中执行此操作
            console.log('进入onload事件11',_this)
            document.getElementById('myrame').contentWindow.postMessage({userId:_this.userId,userName:_this.userName}, "*")
        }
      },
    }
    </script>
    

    B系统子页面(index.html):代码如下:

    console.log('index.html',window.addEventListener)
    window.addEventListener('message', function (e) {
        // 接收到容器页面传递到数据
        console.log('event11: ', e.data);
    });
    

    控制台输出如图所示: 在这里插入图片描述

注意: 利用postMessage传参有两个坑

  1. 如果初始化加载完成就需要传参,则直接将postMessage中写在window.onload即可
  2. window.onload中是获取不到vue实例的,所以这里需要先将this对象先赋值,这样就可以将实例中的data变量传参
  JavaScript知识库 最新文章
ES6的相关知识点
react 函数式组件 & react其他一些总结
Vue基础超详细
前端JS也可以连点成线(Vue中运用 AntVG6)
Vue事件处理的基本使用
Vue后台项目的记录 (一)
前后端分离vue跨域,devServer配置proxy代理
TypeScript
初识vuex
vue项目安装包指令收集
上一篇文章      下一篇文章      查看所有文章
加:2022-09-13 11:05:12  更:2022-09-13 11:06:52 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/11 13:51:23-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码