首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >尝试使用动态javascript:我可以递归地动态包含吗?

尝试使用动态javascript:我可以递归地动态包含吗?
EN

Stack Overflow用户
提问于 2010-10-13 21:08:20
回答 2查看 126关注 0票数 1
代码语言:javascript
复制
function helloworld() {
    alert('hello world');
}

静态html:

代码语言:javascript
复制
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
    <title></title>
    <script src="helloworld.js" type="text/javascript"></script>
</head>
<body>
    <form action="#">
     <input type="button" onclick="helloworld()" />
    </form>
</body>
</html>

使用http://accessify.com/tools-and-wizards/developer-tools/html-javascript-convertor/进行第一次转换:

代码语言:javascript
复制
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
    <title></title>
    <script src="helloworld.js" type="text/javascript"></script>
</head>
<body>
    <form action="#">

     <script type="text/javascript">
         document.write("<input type=\"button\" onclick=\"helloworld()\" \/>");
     </script>

    </form>
</body>
</html>

第二次转换不起作用:

代码语言:javascript
复制
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
    <title></title>
    <script src="helloworld.js" type="text/javascript"></script>
</head>
<body>
    <form action="#">

     <script type="text/javascript">
document.write("     <script type=\"text\/javascript\">");
document.write("         document.write(\"<input type=\\"button\\" onclick=\\"helloworld()\\" \\/>\");");
document.write("     <\/script>");

     </script>

    </form>
</body>
</html>

有没有可能纠正第二个代码,使它可以工作?

EN

回答 2

Stack Overflow用户

发布于 2010-10-13 21:19:05

代码语言:javascript
复制
<script type="text/javascript">
            document.write("     <script type=\"text\/javascript\">");
            document.write("document.write('<input type=\"button\" onclick=\"helloworld()\" />');");
            document.write("     <\/script>");
</script>

将输出

编辑

检查完fire bug后,生成的代码如下所示。

代码语言:javascript
复制
<script type="text/javascript">
    document.write('<input type="button" onclick="helloworld()" />');     
</script>
<input onclick="helloworld()" type="button">
票数 2
EN

Stack Overflow用户

发布于 2010-10-13 21:19:49

这样如何:

代码语言:javascript
复制
      ..
      <form action='#'>
      </form>

      <script type="text/javascript">
        window.addEventListener('load', function() {
          var inp = document.createElement('input');
          inp.setAttribute('type', 'button');
          input.addEventListener('click', function() {
            ..
          }, false);

          document.forms[0].appendChild(inp);
        }, false);
      </script>

当然,它更长,但它是有效的,这是做这件事的“适当”方式(使用jQuery之外)。

代码语言:javascript
复制
    </body>
  </html>
票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/3923962

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档