我想将所有html元素中的所有拉丁数字转换为阿拉伯数字,但文本字段,带有jQuery的textarea标签除外。
arabic digits=('۰','۱','۲','۳','۴','۵','۶','۷','۸','۹');
latin digits=('0','1','2','3','4','5','6','7','8','9');
我知道正则表达式是将所有阿拉伯语转换为数字的解决方案,但我的工作是仅转换指定html标记中的文本。
最佳答案
从您对问题的评论看来,您似乎不希望只使用div
,span
和p
元素,而不是所有不构成字段的元素。
您可以使用以下方法遍历页面上的所有非表单字段元素:
$("*:not(textarea, input, select)").each(function() {
// ...do something here...
});
在函数中,您可以使用
.contents()
(获取所有子节点,包括文本节点)和.filter
(过滤掉除文本节点以外的所有内容),仅更新元素的文本(而不是其后代元素中的任何文本)。和.each
(以遍历其余子项);然后更新this.nodeValue
以更新文本节点的文本:$("*:not(textarea, input, select)").each(function() {
$(this).contents().filter(function() {
return this.nodeType === 3; // 3 = text node
}).each(function() {
this.nodeValue = this.nodeValue.replace(/*...your regex replacement here...*/);
});
});
您似乎在说您知道如何用正则表达式进行替换,但是在下面您建议您不要这样做。这是一种相当简单的方法:
一次,预先:
var arabicToLatinMap = {
"۰": "0",
"۱": "1",
"۲": "2",
"۳": "3",
"۴": "4",
"۵": "5",
"۶": "6",
"۷": "7",
"۸": "8",
"۹": "9"
};
var arabicRegEx = /[۰۱۲۳۴۵۶۷۸۹]/g;
然后在相关位置:
this.nodeValue = this.nodeValue.replace(arabicRegEx, function(digit) {
return arabicToLatinMap[digit];
});
旁注:0、1、2、3等不是拉丁数字。有趣的是,它们是阿拉伯数字,只是它们是西阿拉伯数字,而不是现在中东使用的东阿拉伯数字。因此,这实际上是一个东西方阿拉伯数字转换器。 :-)西方世界的数字来自大约9世纪至10世纪阿拉伯世界的杰出数学家。