1

JavaScript で完全な HTML ページを動的に作成することは可能ですか?

基本的に、私はブラウザーで HTML エディターを作成しています。私がやりたいことは、画面の上部のテキスト領域に HTML コードを配置し、画面の下部に HTML ページのプレビューを表示することです。問題は、それは単なる小さな HTML div と css ではなく、JavaScript インクルードと CSS スタイルシートへのリンクをサポートする必要がある完全な HTML ページになるということです。

したがって、たとえば、テキストエリア「editor」には、次のような完全な 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

AJAX が開始される数日前にバックグラウンド サーバー通信を行う際によく使用されるトリックについては、https: //stackoverflow.com/a/10433550/1363613 を参照してください。

IFrame 要素を作成し、偽の src を設定して、IFrame を現在のドキュメントに追加し、(iframeEl.document.write を介して) 書き込みを開始してみてください。

タイムアウトや不正な形式の html などの他の外部イベントが原因で IFrame ドキュメントが閉じられる可能性があることを考慮する必要があります。そのため、同じ JavaScript 関数/クロージャで書き込みを実行してください。

この手法は基本的に、document.write を介して書き込むことができるtext -input-stream を開きます。次に、通常の読み込み Web ページは、websocket -input-stream を介してそのソースを取得します。

于 2013-11-12T22:04:24.350 に答える