How do I use JQuery to remove all “script” tags in a string of HTML?

后端 未结 4 438
离开以前
离开以前 2020-12-09 04:15

Suppose I have a string of HTML code. I want to use JQuery to remove all

相关标签:
4条回答
  • 2020-12-09 04:45

    i guess this should work

    $('script').each(function () {
        $(this).remove();
    });
    
    0 讨论(0)
  • 2020-12-09 04:46

    This should work for you:

    var stringOfHtml = // your string here
    $(stringOfHtml).find('script').remove();
    

    To get the new string with the script tags removed:

    var stringOfHtml = "<div><script></script><span></span></div>";
    var html = $(stringOfHtml);
    html.find('script').remove();
    
    var stringWithoutScripts = html.wrap("<div>").parent().html(); // have to wrap for html to get the outer element
    

    JS Fiddle Example - Had to use p instead of script as script broke the fiddle, same principle though.

    Actual working answer here (hopefully)

    Here is a workaround for the script issue, use replace to swap the script text with something else (try and make it unique) then remove those new tags and use replace again to swap back in case script is used anywhere else in text. Yes, it does use regex, but not to remove the script tags so I'm hoping that's alright ;):

    var stringOfHtml = "<p></p><script>alert('fail');</scr" + "ipt><span></span>";
    var wrappedString = '<div>' + stringOfHtml + '</div>';
    var noScript = wrappedString.replace(/script/g, "THISISNOTASCRIPTREALLY");
    var html = $(noScript);
    html.find('THISISNOTASCRIPTREALLY').remove();
    
    alert(html.html().replace(/THISISNOTASCRIPTREALLY/g, 'script'));
    

    JS Fiddle Workaround

    JS Fiddle Example With Script Text

    0 讨论(0)
  • 2020-12-09 04:57

    Here is the other solution if one want to remove script tag from any string:

    var str = "<script>Content...</script>"
    use var afterstring = str.replace("<script>","new");
    and afterstring = str.replace("<\/script>","new");
    


    Hope it will work for you !

    0 讨论(0)
  • 2020-12-09 05:04

    Old question, but if you are still looking for the easiest way to remove scripts from a string try

    $.parseHTML(string);  
    

    $.parseHTML() automatically removes script tags from strings.

    Edit:

    This works because keepScripts has false value as default. (Reference: $.parseHtml)

    $.parseHTML(data, context, keepScripts)
    
    0 讨论(0)
提交回复
热议问题