javascript - 转义小于/大于 javascript

标签 javascript jquery string escaping

我在尝试转义某些代码时遇到问题...基本上,我想转义“<”和“>”,但我希望它们在我的#output div 中作为“<”和“>”出现。目前,它们显示为“<”和“>”在页面上。

这显然是为了防止任何人在页面上利用/注入(inject)脚本。这是我的代码:

var textval = $("#textarea").val();                   //textarea

filtered = textval.replace(/</gi,"&lt;");           //replace "<"

$("#output").html(filtered);                     //insert textarea data into div

任何人都可以发现我做错了什么,或者有更好的方法吗?

非常感谢

编辑:我确实想要一些 html 标签(比如 可以工作,所以我不能使用 $.text(); 不幸的是..)

最佳答案

试试这个:

var textval = $("#textarea").val();
$("#output").text(textval);      

jQuery 提供了两种方法 - $.text() 和 $.html(),其中方法名称不言自明:)

关于javascript - 转义小于/大于 javascript,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/5225096/

相关文章:

javascript - 正则表达式在Javascript中获取括号之间的字符串

c++ - 顺序 key 生成

Javascript 显示用户输入

javascript - 类型错误 : Cannot read property 'node' of undefined

javascript - Meteor:循环模板的模板级别订阅或所有订阅完成时

jquery - 如何防止用户在等待ajax响应时进行交互?

php - 为什么在 php 中存在二进制安全和二进制不安全函数?

php - 如何使用 javascript 或 php 统计网站当前访问者

javascript - 通过数据库中的处理状态轮询 Sidekiq 作业是否完成

javascript - PhoneGap-Plugin-Push 或 jQuery/Ajax