blob html 预览_iframe和HTML5 blob实现JS,CSS,HTML直接当前页预览
这篇文章发布于 2017年08月24日,星期四,01:09,归类于 js实例。 阅读 1755 次, 今日 1350 次
一、关于前端代码效果实时预览
前端代码效果实时预览的需求实际上是非常常见的,例如jsbin,codepen,runjs之类的网站就是满足此需求的。这些站点可以方便快捷的让我们测试一些前端属性的作用和表现,还可以制作可编辑可分享的在线demo,遇到棘手或者不明白问题的时候,给对方一个这样的在线demo地址是最友好的做法。
当然需求场景还不止这些,比方说我们制作一些工具,例如类似玉兔这样的H5制作工具,就有能够实时预览最终效果的需求。又或者说我们写技术文章的时候,文章里面嵌入的源代码,希望可以直接跑起来。
传统做法是这样子的,会新建一个另外的独立页面,专门用来接收传入的前端代码,通过新开窗口或者嵌入iframe页面的方式达到最终效果,其中可能会用到HTML5 postMessage等通信技术。
然而实际上,对于这个预览效果,如果代码是我们自己控制,而不是全权交给用户编辑的,是没有必要新建一个另外的预览页面,亦或者是在新窗口(新标签页)中浏览的。可以直接在当前页面构建一个文档上下文,实现更加方便快捷的预览。
二、借助iframe和blob实现前端代码的实时预览
我们直接看一个例子(如果没有效果,请前往文章原出处体验),如下CSS和HTML代码(纯CSS实现了一个水波荡漾的效果):
html {
height: 100vh;
}
body {
height: inherit;
background: #2e576b;
display: -ms-grid;
display: grid;
}
.container {
margin: auto;
}
.card {
position: relative;
width: 300px; height: 350px;
background: #fff;
border-radius: 2px;
box-shadow: 0 2px 15px 3px rgba(0, 0, 0, 0.08);
overflow: hidden;
}
.card::after {
content: '';
display: block;
width: 100%; height: 100%;
background: linear-gradient(to bottom, #0065a8, rgba(221, 238, 255, 0.4) 46%, rgba(255, 255, 255, 0.5));
}
.wave {
position: absolute;
top: 3%; left: 50%;
width: 400px; height: 400px;
margin-top: -200px; margin-left: -200px;
background: #0af;
border-radius: 40%;
opacity: .4;
animation: shift 3s infinite linear;
}
.wave.w2 {
background: yellow;
opacity: .1;
animation: shift 7s infinite linear;
}
.wave.w3 {
animation: shift 5s infinite linear;
background: crimson;
opacity: 0.1;
}
@-webkit-keyframes shift {
from {
transform: rotate(360deg);
}
}
@keyframes shift {
from {
transform: rotate(360deg);
}
}
点击代码演示区域右上角或右下角的运行按钮,此时这段代码的效果就干干净净(不受当前页CSS,JS干扰)地在当前页面显示了(点击页面空白区域隐藏)。
点击后页面截图如下:
核心原理:
此效果实现的核心原理是:
创建元素;
将CSS,HTML字符串转换为Blob对象;
使用URL.createObjectURL()方法将Blob对象转换为URL对象并赋予我们创建的元素的src属性;
使用JavaScript代码表示更加一目了然:
// 1. 创建元素
var iframe = document.createElement('iframe');
// 2. 将CSS,HTML字符串转换为Blob对象
var blob = new Blob([htmlCode], {
'type': 'text/html'
});
// 3. 使用URL.createObjectURL()方法将...
iframe.src = URL.createObjectURL(blob);
需要注意的是,当我们使用 new Blob() 对我们的字符数据进行转换的时候,一定要指定type为text/html,否则,HTML代码会被自动转移为安全的纯文本显示在元素中。
兼容性
IE浏览器遗憾并不支持src直接是URL对象。
所以此技术只适用于对兼容性没有严格要求的一些项目。
三、结束语
其实很多效果,我们直接在结束当前页面的window上下文预览也没什么,但是有一些效果就不行,例如,预览针对响应式布局的media屏幕宽度查询下的效果,必须是真实的窗体宽度才会触发CSS查询语句的执行,此时,只能在中预览,我们只要把元素宽度设置到我们需要的大小就可以了,例如,需要预览类似如下CSS代码效果:
@media screen and (max-width:480px) {
img { max-width: 100%; }
}
只要设置元素宽度为480像素就可以了。
以上就是本文内容,希望能对你的项目开发有所帮助。
感谢阅读!
本文为原创文章,会经常更新知识点以及修正一些错误,因此转载请保留原出处,方便溯源,避免陈旧错误知识的误导,同时有更好的阅读体验。
本文地址:http://www.zhangxinxu.com/wordpress/?p=6368
(本篇完)
分享到:
blob html 预览_iframe和HTML5 blob实现JS,CSS,HTML直接当前页预览相关推荐
- iframe和HTML5 blob实现JS,CSS,HTML直接当前页预览
所以此技术只适用于对兼容性没有严格要求的一些项目. 三.结束语 其实很多效果,我们直接在结束当前页面的window上下文预览也没什么,但是有一些效果就不行,例如,预览针对响应式布局的media屏幕宽度 ...
- blob html 预览_前端读取Blob内容
简述 前端由于安全方面的因素,不能直接对文件进行写操作.但是在实际的业务需求中,难免会遇到各种各样文件的下载.预览. 如果服务端下载文件是以流的形式传递到前端,前端通常是将流转换为objectURL, ...
- [转] HTML5 Blob与ArrayBuffer、TypeArray和字符串String之间转换
1.将String字符串转换成Blob对象 //将字符串 转换成 Blob 对象 var blob = new Blob(["Hello World!"], {type: 'tex ...
- html5图片自动翻转,纯js实现360度旋转预览图片特效
这是一款纯js实现360度旋转预览图片特效.该js特效仅使用120行代码,即可实现通过滑块.或鼠标手动360度旋转图片,以及自动360度旋转图片的效果. 使用方法 HTML结构 import Roll ...
- js实现图片上传预览及进度条
js实现图片上传预览及进度条 原文js实现图片上传预览及进度条 最近在做图片上传的时候,由于产品设计的比较fashion,上网找了比较久还没有现成的,因此自己做了一个,实现的功能如下: 1:去除浏览器 ...
- VUE预览PDF文件并利用pdf.js获取鼠标选中的文字和搜索,在iframe中获取选中文字,监听鼠标事件,右键菜单
一.VUE预览PDF文件并利用pdf.js获取鼠标选中的文字和搜索 需求实现:vue实现预览pdf文件,获取到鼠标选中的文字数据.调用pdf.js自带的搜索方法实现搜索功能(后期可以调用该接口满足其他 ...
- php 图片预览原理,JavaScript_纯JS实现的批量图片预览加载功能,1.实现原理直接见代码,需要一 - phpStudy...
纯JS实现的批量图片预览加载功能 1.实现原理直接见代码,需要一张转圈的小图片,需要预览的所有图片默认的位置全是这张小图片,滚轮滚到原图需要出现的位置时候,预览加载替换小图片.实现效果 复制代码 代码 ...
- js实现移动端图片预览:手势缩放, 手势拖动,双击放大...
原文:js实现移动端图片预览:手势缩放, 手势拖动,双击放大... 前言 本文将介绍如何通过js实现移动端图片预览,包括图片的 预览模式,手势缩放,手势拖动,双击放大等基本功能: 扫码查看示例效果: ...
- [css] 如何做图片预览,如何放大一个图片?
[css] 如何做图片预览,如何放大一个图片? 图片不跨域的话用 canvas 来 drawImage 放大裁剪也可以. 个人简介 我是歌谣,欢迎和大家一起交流前后端知识.放弃很容易, 但坚持一定很酷 ...
最新文章
- tinyxml 读取文本节点_TinyXml 读写XML文件
- 今晚中科院刘永鑫报告:宏基因组数据分析的机遇与挑战
- Web 开发在 2015 年及未来的发展趋势
- C#LeetCode刷题之#62-不同路径(Unique Paths)
- akka之分发和路由
- 小白入门使用Nginx基础的常用操作
- 如何将GridViewEX升级到UWP(Universal Windows Platform)平台
- nginx反向代理:配置多个应用通过80端口访问(PHP项目)
- java编程之美(一)
- ICIP论文结构整理
- Windows右键菜单
- 存储过程(无参,IN多个输入参数,OUT多个输出参数,INOUT输入输出)
- IDEA 自定义代码模板
- 最好用的 6 款 Vue 实时消息提示通知(Message/Notification)组件推荐与测评
- 日本杂货连锁店Loft首家海外直营店于上海开业
- 呼吸机氧电池的工作原理及性能检测
- 信雅达,一家不尊重应聘者的公司
- 计算机网络之无线局域网
- 网络程序设计——VC的多线程编程(线程与进程)
- springboot——项目install报错