1

是否可以在 JavaScript 中动态创建完整的 HTML 页面?

基本上,我正在浏览器中创建一个 HTML 编辑,我想做的是在屏幕顶部的文本区域中放置 HTML 代码,并在屏幕底部放置 HTML 页面的预览。问题是它不仅仅是小的 HTML div 和 css,它将是一个完整的 HTML 页面,需要支持指向 JavaScript 包含和 CSS 样式表的链接。

因此,例如,文本区域“编辑器”将包含完整 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,它仅适用于预览页面并被沙盒化。这可能吗?

4

2 回答 2

2

请参阅https://stackoverflow.com/a/10433550/1363613了解在 AJAX 启动前几天进行后台服务器通信时经常使用的技巧。

尝试创建一个 IFrame 元素,设置一个虚假的 src,将 IFrame 附加到当前文档,然后开始写入它(通过 iframeEl.document.write)。

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

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

于 2013-11-12T22:04:24.350 回答
0

您可以获得的最接近的是 iFrame。您可以使用 c++、c+、c、java 甚至 python 来做其他事情。

然而,你应该首先做的是用谷歌搜索它。这是我为您找到的结果。点击我!(也可能重复。)

于 2013-11-09T03:29:21.720 回答