![](/img/trans.png)
[英]How to create an element dynamically in an html page using javascript?
[英]How to create an HTML page dynamically in JavaScript
是否可以在JavaScript中动态创建完整的HTML页面?
基本上,我在浏览器中创建一个HTML编辑器 ,我想要做的是在屏幕顶部的文本区域中显示HTML代码,在屏幕底部显示HTML页面的预览。 问题是它不仅仅是小型的HTML div和css,它还是一个完整的HTML页面,需要支持JavaScript包含和CSS样式表的链接。
因此,例如,textarea“编辑器”将包含完整HTML页面的源代码,如下所示:
<!DOCTYPE html>
<!--[if lt IE 7]> <html class="no-js lt-ie9 lt-ie8 lt-ie7"> <![endif]-->
<!--[if IE 7]> <html class="no-js lt-ie9 lt-ie8"> <![endif]-->
<!--[if IE 8]> <html class="no-js lt-ie9"> <![endif]-->
<!--[if gt IE 8]><!--> <html class="no-js"> <!--<![endif]-->
<head>
<meta charset="utf-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<title></title>
<meta name="description" content="">
<meta name="viewport" content="width=device-width, initial-scale=1">
<!-- Place favicon.ico and apple-touch-icon.png in the root directory -->
<link rel="stylesheet" href="css/normalize.css">
<link rel="stylesheet" href="css/main.css">
<script src="js/vendor/modernizr-2.6.2.min.js"></script>
</head>
<body>
<!--[if lt IE 7]>
<p class="browsehappy">You are using an <strong>outdated</strong> browser. Please <a href="http://browsehappy.com/">upgrade your browser</a> to improve your experience.</p>
<![endif]-->
<!--content-->
<script src="//ajax.googleapis.com/ajax/libs/jquery/1.10.2/jquery.min.js"></script>
<script>window.jQuery || document.write('<script src="js/vendor/jquery-1.10.2.min.js"><\/script>')</script>
<script src="js/plugins.js"></script>
<script src="js/main.js"></script>
<!-- Google Analytics: change UA-XXXXX-X to be your site's ID. -->
<script>
(function(b,o,i,l,e,r){b.GoogleAnalyticsObject=l;b[l]||(b[l]=
function(){(b[l].q=b[l].q||[]).push(arguments)});b[l].l=+new Date;
e=o.createElement(i);r=o.getElementsByTagName(i)[0];
e.src='//www.google-analytics.com/analytics.js';
r.parentNode.insertBefore(e,r)}(window,document,'script','ga'));
ga('create','UA-XXXXX-X');ga('send','pageview');
</script>
</body>
</html>
然后它将在HTML编辑器的预览中。 事实上,它实际上与我正在输入的StackOverflow编辑器非常相似(在此下面有一个渲染预览 - 附加图像)。
我想保持域分离,以便如果预览加载JS或CSS它只适用于预览页面并且是沙箱。 这可能吗?
请参阅https://stackoverflow.com/a/10433550/1363613,了解在AJAX启动前几天进行后台服务器通信时经常使用的技巧。
尝试创建一个IFrame元素,设置一个伪造的src,将IFrame附加到当前的Document,然后开始写入它(通过iframeEl.document.write)。
您需要考虑到,IFrame文档可能会因为一些其他外部事件(如超时或格式错误的HTML等)而关闭。因此,请确保在相同的javascript函数/闭包中执行写入。
该技术基本上打开一个文本输入流,您可以通过document.write写入。 反过来,正常加载网页通过websocket -input-stream检索其源。
最接近的是iFrame。 你可以用c ++,c +,c,java甚至python做其他事情。
不过你应该首先做些什么,用google搜索它。 这是我找到的结果。 点击我! (也可能是重复的。)
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.