如何在JavaScript中动态创建HTML页面

如何在JavaScript中动态创建HTML页面,javascript,html,css,Javascript,Html,Css,可以用JavaScript动态创建完整的HTML页面吗 基本上,我正在浏览器中创建一个HTML编辑器,我想做的是将HTML代码放在屏幕顶部的文本区域中,并在屏幕底部预览HTML页面。问题是它不仅仅是一个小的HTML div和css,它将是一个完整的HTML页面,需要支持指向JavaScript include和css样式表的链接 例如,textarea“编辑器”将包含完整HTML页面的源代码,如下所示: <!DOCTYPE html> <!--[if lt IE 7]>

可以用JavaScript动态创建完整的HTML页面吗

基本上,我正在浏览器中创建一个HTML编辑器,我想做的是将HTML代码放在屏幕顶部的文本区域中,并在屏幕底部预览HTML页面。问题是它不仅仅是一个小的HTML div和css,它将是一个完整的HTML页面,需要支持指向JavaScript include和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>

window.jQuery | | document.write(“”)
(函数(b,o,i,l,e,r){b.GoogleAnalyticsObject=l;b[l]| |(b[l]=
函数(){(b[l].q=b[l].q | |[]).push(参数)});b[l].l=+新日期;
e=o.createElement(i);r=o.getElementsByTagName(i)[0];
e、 src='//www.google-analytics.com/analytics.js';
r、 parentNode.insertBefore(e,r)}(窗口,文档,'script','ga');
ga(“创建”,“UA-XXXXX-X”);ga('send','pageview');
然后在它下面是HTML编辑器的预览。事实上,它与我现在输入的StackOverflow编辑器非常相似(在这个附加图像的正下方有一个渲染预览)


我想保持域分开,这样如果预览加载JS或CSS,它只应用于预览页面,并且是沙盒。这可能吗

最接近的是iFrame。你可以用C++、C++、java、甚至python做其他事情。 然而,你首先应该做的是用谷歌搜索它。这是我为你找到的一个结果。(也可能是重复的。)

请参阅我在AJAX开始使用前几天进行后台服务器通信时经常使用的技巧

尝试创建一个IFrame元素,设置一个伪src,将IFrame附加到当前文档中,然后开始写入(通过iframeEl.Document.write)

您需要考虑到,IFrame文档可能会由于某些其他外部事件(如超时或格式错误的html等)而关闭。因此,请在相同的javascript函数/关闭中执行写入操作以确保安全


该技术基本上会打开一个文本输入流,您可以通过document.write对其进行写入。反过来,正常加载的网页通过websocket输入流检索其源。

您可以尝试使用iframe查看iframe可能与您在浏览器中看到的最接近。您可以使用C#或Java创建一个厚客户端应用程序。在顶部放置一个文本框,在底部放置一个web浏览器控件。将文本框的内容保存为临时目录中的网页,并将所述网页加载到web浏览器控件中。保存时刷新等。您在IDE中看到的典型内容。我的意思是说这是在浏览器中运行的。您将访问此网站,编辑器将位于顶部,预览将位于底部。@megawac该链接有帮助。评论说它在IE中不起作用。该页面上的链接指向另一个在IE中有效的答案,但该示例仅显示设置正文内容,而不是完整的HTML页面@1.21千兆瓦在这种情况下,这是不可能做到的。唯一的解决方案是局部的,一个iFrame。