angular6中将字符串转为html,Angular.js中的部分HTML字符串转义

Kevin Hakans..

5

让我们从重构你的内容开始,logEntry将interpolateParams分开

var translationId = 'Log.' + msg.context.entity_type) + '.' + msg.context.action;

var interpolateParams = {

'object_name': msg.context.object_name,

'user': msg.context.user_name

};

var translated = $translate(translationId, interpolateParams);

return $sce.trustAsHtml(translated);

您想要从中转义所有HTML,interpolateParams但在翻译模板中保留任何HTML.使用此代码复制对象,迭代其值并替换为转义的HTML.

var safeParams = angular.copy(interpolateParams);

angular.forEach(safeParams, function(value, key, obj) {

obj[key] = encodeEntities(value)

// if you want safe/sanitized HTML, use this instead

// obj[key] = $sanitize(value);

});

var translated = $translate(translationId, safeParams);

最后,encodeEntitiesangular 的功能没有暴露,因此我们不得不从angular-sanitize.js借用源代码

var SURROGATE_PAIR_REGEXP = /[\uD800-\uDBFF][\uDC00-\uDFFF]/g,

// Match everything outside of normal chars and " (quote character)

NON_ALPHANUMERIC_REGEXP = /([^\#-~| |!])/g;

function encodeEntities(value) {

return value.

replace(/&/g, '&').

replace(SURROGATE_PAIR_REGEXP, function(value) {

var hi = value.charCodeAt(0);

var low = value.charCodeAt(1);

return '' + (((hi - 0xD800) * 0x400) + (low - 0xDC00) + 0x10000) + ';';

}).

replace(NON_ALPHANUMERIC_REGEXP, function(value) {

return '' + value.charCodeAt(0) + ';';

}).

replace(/

replace(/>/g, '>');

}

更新:更新为angular-translate 2.7.0后出现此消息:

pascalprecht.translate.$ translateSanitization:未配置清理策略.这可能会产生严重的安全隐患.有关详细信息,请参见

http://angular-translate.github.io/docs/#/guide/19_security.

Sp代替trustlate上面的答案,angular-translate可以完成相同的结果:

$translateProvider.useSanitizeValueStrategy('escapeParameters');

有关更多Sanitize Value Strategies的信息,请参阅文档

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值