javascript - 将 javascript 生成的框架转换为 div

标签 javascript html frames

我有一些旧代码正在尝试转换为 div。它包含没有目标 src 的框架,只有 JavaScript 来生成页面。

下面是代码...

var editboxHTML =
  '<html class="expand close">' +
  '<head>' +
  '<style type="text/css">' +
  '.expand { width: 100%; height: 100%; }' +
  '.close { border: none; margin: 0px; padding: 0px; }' +
  'html,body { overflow: hidden; }' +
  '<\/style>' +
  '<\/head>' +
  '<body class="expand close" onload="document.f.ta.focus(); document.f.ta.select();">' +
  '<form class="expand close" name="f">' +
  '<textarea class="expand close" name="ta" wrap="hard" spellcheck="false">' +
  '<\/textarea>' +
  '<\/form>' +
  '<\/body>' +
  '<\/html>';
var defaultStuff = 'This top frame is where you put your code.';
var extraStuff = '';
var old = '';

function init() {
  window.editbox.document.write(editboxHTML);
  window.editbox.document.close();
  window.editbox.document.f.ta.value = defaultStuff;
  update();
}

function update() {
  var textarea = window.editbox.document.f.ta;
  var d = dynamicframe.document;
  if (old != textarea.value) {
    old = textarea.value;
    d.open();
    d.write(old);
    if (old.replace(/[\r\n]/g, '') == defaultStuff.replace(/[\r\n]/g, ''))
      d.write(extraStuff);
    d.close();
  }
  window.setTimeout(update, 150);
}
<frameset onload="init();" rows="50%,50%" resizable="no">
  <frame name="editbox" src="javascript:'';">
  <frame name="dynamicframe" src="javascript:'';">
</frameset>

此代码的顶部有一个用户输入框,用于输入 HTML 代码,底部显示该代码在浏览器中的外观。

我如何操作这段代码来使用 div 而不是框架,这样我就可以包含额外的样式,并且它在 HTML5 中不会完全被弃用。

如果您的答案包含 AJAX,请您解释一下,因为我不熟悉该编码。

编辑:如果没有 div 替代方案,是否有 iframe 替代方案?

最佳答案

答案已更新
CSS 固定
错误已修复

Jquery方式:

<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.4/jquery.min.js"></script>
<script>
    var editboxHTML =
      '<html class="expand close">' +
      '<head>' +
      '<style type="text/css">' +
      '.expand { width: 100%; height: 50%; }' +
      '.close { border: none; margin: 0px; padding: 0px; }' +
      'html,body { overflow: hidden; }' +
      '<\/style>' +
      '<\/head>' +
      '<body class="expand close">' +
      '<form class="expand close" name="f">' +
      '<textarea class="expand close" name="ta" wrap="hard" spellcheck="false">qweqwe' +
      '<\/textarea>' +
      '<\/form>' +
      '<\/body>' +
      '<\/html>';
    var defaultStuff = 'This top frame is where you put your code.';
    var extraStuff = '';
    var old = '';

    function init() {
        $("#editbox").html(editboxHTML);
        $("#editbox form[name='f'] [name='ta']").focus();
        $("#editbox form[name='f'] [name='ta']").val(defaultStuff);
        update();
    }

    function update() {
      var textarea = $("#editbox form[name='f'] [name='ta']");
      var d = $("#dynamicframe");
      if (old != textarea.val()) {
        old = textarea.val();
        if (old != undefined){
            d.html(old);
            if (old.replace(/[\r\n]/g, '') == defaultStuff.replace(/[\r\n]/g, '')){
                d.append(extraStuff);
            }
        }
        else{
            d.html("old undefined");
        }
      }
      setTimeout("update()", 150);
    }
</script>
<button onclick="init()">EDIT</button>
<div id="editbox"></div>
<div id="dynamicframe"></div>

关于javascript - 将 javascript 生成的框架转换为 div,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36540850/

相关文章:

javascript - 表单的 Jquery 表单验证

javascript - navigator.mediaDevices 未定义

javascript - 如何跨框架访问元素?

Javascript 语法错误意外标记(文件输入)

javascript - Rails 中的砌体 - 刷新时框有时不对齐

javascript - 将 Canvas 笔划剪辑到图像

Javascript onclick 用作退格按钮以删除插入符号前的字符

Java - 是否可以将 JMenuBar 添加到 JFrame 的装饰窗口?

html - 带框架的力域

javascript - Lightbox:图像描述的其他属性(而不是标题)