当前位置:  开发笔记 > 编程语言 > 正文

逃避Javascript的困境

如何解决《逃避Javascript的困境》经验,为你挑选了1个好方法。

我有以下内容

var id='123';

newDiv.innerHTML = "";

哪个呈现在我的HTML中.

我遇到的问题是我希望调用方法TestFunction,并在我的函数StepTwo(string,boolean)中用作字符串参数,理想情况下最终会显示在实时HTML中,如图所示......


注意TestFunction在这里是一个字符串(它在StepTwo中使用eval执行).

我试图通过以下方式格式化我的JS:

newDiv.innerHTML = "";

虽然这在我的IDE中看起来是正确的,但在渲染的HTML中,它仍然无法相信.

如果有人能指出我正确的方向,我将不胜感激.谢谢!



1> Kent Fredric..:

互联网上最大的资本失败之一是通过将字符串粘合在一起来在javascript中创建html.

var mya = document.createElement("a");
mya.href="#"; 
mya.onclick = function(){ 
    StepTwo(function(){ 
        TestFunction('123', false ); 
    }, true );   
};
newDiv.innerHTML = ""; 
newDiv.appendChild(mya);

这消除了任何花哨逃避的需要.

(我可能应该'onclick'不同,但这应该工作,我努力不要只使用jQuery代码来做所有事情)

继承人我将如何在jQuery中做到这一点:

jQuery(function($){ 

  var container = $("#container"); 
  var link = document.createElement("a"); /* faster than  $(""); */
  $(link).attr("href", "Something ( or # )" ); 
  $(link).click( function(){ 
       var doStepTwo = function()
       { 
            TestFunction('123', true ); 
       };
       StepTwo( doStepTwo, false );  /* StepTwo -> doStepTwo -> TestFunction() */
  });
  container.append(link); 
}); 

在Javascript中将字符串粘合在一起没有很好的借口

它所做的就是将HTML解析回到dom结构的ADD开销,以及基于XSS的破坏HTML的ADD潜力.甚至心爱的谷歌在他们的一些广告剧本中也犯了这个错误,并且在我见过的许多情况下都引起了史诗般的失败(而且他们不想知道它)

我不明白Javascript是唯一的借口,而且它不是一个好的借口.

推荐阅读
oDavid_仔o_880
这个屌丝很懒,什么也没留下!
DevBox开发工具箱 | 专业的在线开发工具网站    京公网安备 11010802040832号  |  京ICP备19059560号-6
Copyright © 1998 - 2020 DevBox.CN. All Rights Reserved devBox.cn 开发工具箱 版权所有