zoukankan      html  css  js  c++  java
  • 跨域 (3) window.name

    window对象有一个name属性,该属性有一个特征:即在一个窗口的生命周期内,窗口载入的所有的页面都是共享一个window.name的,每一个页面对window.name都有读写的权限,window.name是持久的存在于一个窗口载入的所有页面中的,并不会因为新的页面的载入而被重置。

    a.html

    <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <meta name="viewport" content="width=device-width, initial-scale=1.0">
        <meta http-equiv="X-UA-Compatible" content="ie=edge">
        <title>a  页面 </title>
    </head>
    <body>
         <!-- a先引用 c -->
        <iframe src="http://localhost:4000/c.html" frameborder="0"  onload="load()"  id="iframe"></iframe>
    </body>
    <script>
      let  first  = true;
      function load() {
          if(first) {
                 //把 a 引用的地址改到b
                    let  iframe =  document.getElementById('iframe')
                    iframe.src= 'http://localhost:3000/b.html'
                    first  = false
          }else {
              console.log(iframe.contentWindow.name)
          }
      }
    </script>
    </html>

    c.html

    <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <meta name="viewport" content="width=device-width, initial-scale=1.0">
        <meta http-equiv="X-UA-Compatible" content="ie=edge">
        <title>Document</title>
    </head>
    <body>
        
    </body>
    <script>
        //   c页面把值放到window 下
       window.name ='hello world'
    </script>
    </html>

    注释:

    a 和 b 是同域名的 http://localhost:3000

    c 是独立的 http://localhost:4000

    a先获取c 的数据

    a先引用 c c把值放到window.name ,把 a 引用的地址改到b

  • 相关阅读:
    jpype
    Java获取类中的所有方法
    SQL中INNER JOIN、LEFT JOIN、RIGHT JOIN、FULL JOIN区别
    如何用命令将本地项目上传到git
    Java连接Mysql:通过配置文件
    lsof -i:port_number
    yum install lsof
    Git的基本使用方法(受益匪浅)
    [后端]gitlab之gitlab-ci自动部署
    centos7安装redis-4.0.1集群
  • 原文地址:https://www.cnblogs.com/guangzhou11/p/11619363.html
Copyright © 2011-2022 走看看