博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
iframe-metamask
阅读量:6175 次
发布时间:2019-06-21

本文共 2948 字,大约阅读时间需要 9 分钟。

iframe--require('iframe')

higher level api for creating and removing iframes in browsers

用于创建或移除浏览器中的iframe的更高层次的API

usage

use with 

与browserify结合使用,安装:

npm install iframe

 

var iframe = require('iframe') // creates a new iframe and appends it to the container,就是把一个添加到id=container的容器中,并在中输出hiframe = iframe({ container: document.querySelector('#container') , body: "hi" }) // completely removes previous iframe from container and generates a new oneframe.setHTML({ body: "bye" })

 

options

you can pass this into the constructor or setHTML

{  name: name of the iframe,  src: if src url is passed in use that (this mode ignores body/head/html options),  body: string contents for ``  head: string contents for ``  html: string contents for entire iframe  container: (constructor only) dom element to append iframe to, default = document.body  sandboxAttributes: array of capability flag strings, default = ['allow-scripts']  scrollingDisabled: (constructor only) boolean for the iframe scrolling attr}

you can also just pass in a string and it will be used as {html: 'yourstring'}

security

by default the sandbox attribute is set with 'allow-scripts' enabled. pass in an array of capability flag strings. :

allow-forms allows form submission.allow-popups allows (shock!) popups.allow-pointer-lock allows (surprise!) pointer lock.allow-same-origin allows the document to maintain its origin; pages loaded from https://example.com/ will retain access to that origin’s data.allow-scripts allows JavaScript execution, and also allows features to trigger automatically (as they’d be trivial to implement via JavaScript).allow-top-navigation allows the document to break out of the frame by navigating the top-level window.

 

gotchas

iframes are weird. here are some things I use to fix weirdness:

loading javascript into iframes

// setTimeout is because iframes report inaccurate window.innerWidth/innerHeight, even after DOMContentLoaded!var body = ''

 

getting rid of dumb iframe default styles

var head = ""

 

实例实现:

iframe.js为:

var iframe = require('iframe') // creates a new iframe and appends it to the container,就是把一个添加到id=container的容器中,并在中输出hi frame = iframe({ container: document.querySelector('#container') , body: "hi" })

然后使用browserify转换iframe.js为浏览器可用版本iframe-bundle.js,然后在html中调用

browserify iframe.js > iframe-bundle.js

 

 index1.html为:

      Iframe Test        

 

然后直接在浏览器中打开html文件

返回结果为,可以看见在页面端把一个<iframe></iframe>添加到id=container的容器中,并在<body></body>中输出hi

 

 

如果添加frame.setHTML({ body: "bye" })

iframe.js为:

var iframe = require('iframe') // creates a new iframe and appends it to the container,就是把一个添加到id=container的容器中,并在中输出hi frame = iframe({ container: document.querySelector('#container') , body: "hi" }) // completely removes previous iframe from container and generates a new one // 这个会将上面设置的iframe移除,重新设置一个,可以从输出看见,现在的输出是bye,而不是hi frame.setHTML({ body: "bye" })

返回结果为:

 

 

 

转载于:https://www.cnblogs.com/wanghui-garcia/p/9848707.html

你可能感兴趣的文章
Exchange Server 2010 创建用户邮箱
查看>>
Win8 Metro(C#)数字图像处理--2.74图像凸包计算
查看>>
mysql--用脚本实现分库分表备份
查看>>
dig挖出DNS的秘密
查看>>
sphinx 增量索引 分布式索引 实例
查看>>
InnoDB Plugin1.0.7的新特性【快速恢复】
查看>>
***iOS 项目的目录结构能看出你的开发经验
查看>>
iptables中state模块的连接状态
查看>>
/usr/local/lib/libltdl.a(ltdl.o): could not read symbols: Bad value
查看>>
秘籍:如何用廉价硬件玩转深度学习,成本不到1000美元
查看>>
nagios(或icinga)将多个主机放到一个组内步骤
查看>>
mybatis-config学习
查看>>
编译安装Nginx实现网络访问多虚拟主机(wordpress+phpmyadmin)
查看>>
Windows 2012 Hyper –V 3.0 New Functions
查看>>
Interpreting an ESX/ESXi host purple diagnostic screen (1004250)
查看>>
linux shell 不同进制数据转换(二进制,八进制,十六进制,base64)
查看>>
源码安装MySQL 5.1 GA
查看>>
苹果电脑获取Android Studio的发布版SHA1和开发版SHA1
查看>>
How to troubleshooting RAC Vip Problem
查看>>
jar 命令 打包装class文件的文件夹
查看>>