### 前言
> 大家都知道这个地方都会有内存泄漏的时候,那么怎么做才是最好的。将src设置为 about:blank 。
```
<iframe name="contentFrame" id="g_iframe" class="g-iframe" scrolling="auto" frameborder="0" src="about:blank" allowfullscreen="true"></iframe>
```
### 问题
> 那么问题就来了,不使用src添加地址,怎么渲染数据了?使获取 iframe dom window对象,进行渲染进去吗?确实是这个思路。进行做了一些操作渲染方法
#### ~~【不能使用】使用 innerHTML~~
> 此方案不通,通过ajax请求,将dom都获取到了,然后在插入 iframe里面:
- 能够将之前的内容替换掉
- 里面的添加的在当前html中脚本不执行(这个就是巨大问题了)
```js
$.ajax({
url: 'xxxxxxxxxxx',
success(html) {
var doc = iframe.contentDocument || iframe.contentWindow.document;
doc.documentElement.querySelector('body').innerHTML = html
// doc.documentElement.innerHTML = html
}
})
```
#### ~~【不能使用】使用 document.write()~~
> 此方案不通。缺点:
- window对象中的 onload、onerror等事件都为null。造成jquery的 $(function () {})
- 如果在执行 document.write() 方法的话,之前的数据还是保留了下来。
```js
$.ajax({
url: 'xxxxxxxxxxx',
success(html) {
var doc = iframe.contentDocument || iframe.contentWindow.document;
// doc.documentElement.body.write(html)
doc.write(html)
}
})
```
#### 【能使用】 使用 location.replace(url)
> 此方案是能解决问题,但是不能使用 location.replace(true) 。缺点:
- 每次都会进行加载新的dom,解决方案:(需要什么模块,通过组页面进行请求,然后在回调,挂在到子对象上。那么这样得封装下模块请求方法了)
```
var doc = iframe.contentDocument || iframe.contentWindow.document;
doc.location.replace(url)
```
- 在子页面,最后做一个判断是否是嵌入到当前的域名下的。
- LOLKU
- 工具类
- form/formData
- form
- formData
- iframe
- 渲染数据,防止内存泄漏
- 获取url(路由)参数
- 常用方法
- 失去焦点软键盘页面乱
- 判断数据类型
- 浏览器全屏
- 动态插入css
- 随机生成自定义长度位数数字
- 验证判断
- localStorage 封装存储
- 格式化日期
- 计算两个时间差
- 去除空格
- 将驼峰命名转换为连字符
- 获取dom属性
- 深拷贝
- class操作
- 判断是否打开浏览器控制台
- 全国城市地区代码表
- canvas合成工具
- 去除emoji表情符号
- 比较两个对象属性和内容(值)一致
- 微信结束页面事件
- 正则匹配url替换域名
- 字符串拼接(渲染dom后传值)
- 判断是否是正则
- 日历算法
- json 工具
- 是否支持webp格式
- h5底部输入框被键盘遮挡问题
- php
- php 二级域名管理
- 单个或者多个域名跨域
- file_get_contents 正确使用
- fromData请求无法携带cookie
- 简单的加密文件传输
- css
- 1px
- 滚动
- ios点击有颜色
- 文本溢出省略号
- css动画抖动
- 文本换行与不换行
- 阻止旋转屏幕时自动调整字体大小
- vue
- vscode 调试
- 新技术
- vue-router 4.0
- vue3
- 基础
- 试验
- javascript
- 上传问题
- 文件选中过,第二次再次选中不触发change事件
- 上传oss
- 后台
- linux搭建服务
- 需安装
- nginx
- 安装
- nginx http 配置二级域名
- nginx https 配置二级域名
- 防止暴力破解
- 阿里申请免费https
- git
- 快速安装
- 配置项
- node
- 安装
- pm2
- mysql
- 安装
- 创建、切换、查询数据库
- 常用命令
- cmake 编译器
- redis
- 软件下载
- git
- 百度git 记住密码
- 经验
- 上传
- 软件
- vscode
- 推荐插件
- 应用开发
- nwjs
- 入门
- package.json
- vue、react、angular 跑nwjs
- 打包
- 监听屏幕
- 运行另一个.exe文件
- node应用
- electron
- 资料
- 安装
- 实战
- 崩溃日志报告
- electron-forge
- 托盘闪烁
- 开机自动启动
- 消息通知
- 禁止默认事件
- 保证只有一个实例
- 打包且美化安装界面
- 创建cli
- 添加Github徽章
- 自动更新
- docsify
- Lowdb存储数据
- 备份、恢复、导入、导出
- 深度链接(协议)唤起Electron应用
- 说明
- 加载扩展插件
- 证书
- Sketch 插件
- 工作
- 宣传文章地址
- api
- tinypng
- npm 插件
- fs封装:fs-jetpack
- 判断是否npm或yarn运行
- 字符串或缓冲区的gzip压缩大小
- 克隆并修改RegExp实例
- 反转对象的键/值
- http路由find-my-way
- dragula 拖拽(拖放)
- svga
- npm 脚手架搭建
- 项目
- 小工具
- svg转图片
- 日历