gpt4 book ai didi

javascript - 使用 JavaScript 更新字符串中的所有数字?

转载 作者:行者123 更新时间:2023-11-29 21:11:20 28 4
gpt4 key购买 nike

主要问题是如何更新字符串中的所有数字?

我想更新字符串中数字的示例:

  • -ms-transform: rotate(7deg);
  • 边距:10px 20px 30px 40px;
  • Value10isMoreThan5

所以数字的每个“ block ”都应该单独处理(例如 101 01px2,无论它是空格还是数字段之间的字符)。

当我使用空格分割字符串时,我得到了这个工作,但在字符串没有空格的情况下它不起作用 rotate(7deg)。这是一小段“意大利面条代码”示例。

// Basic lerp
function lerp (min, max, amount) {
return min + amount * (max - min);
}

// Lerp values in string
function lerpAllNumbers (a, b, amount) {
var aNumbers = separateNumbers(a);
var bNumbers = separateNumbers(b);
var returnValue = null;
if (aNumbers.length === bNumbers.length) {
for (var i = 0; i < aNumbers.length; i++) {
var searchString = aNumbers[i].value + aNumbers[i].extension;
var newValue = lerp(aNumbers[i].value, bNumbers[i].value, amount).toFixed(3) + aNumbers[i].extension;
returnValue = a.toString().replace(searchString, newValue);
}
return returnValue;
}
}

// Separate numbers from string and create object with value and extension
function separateNumbers(text) {
var splitter = text.toString().split(" ");
var returnArray = [];
splitter.forEach(function(item){
var numberObj = {
value: parseFloat(item),
extension: item.replace(/^-?\d+((.|,)\d+)?/g, '')
}
returnArray.push(numberObj);
});
return returnArray;
}

如有重复请见谅。我已经找到像这样的有用帖子:regex to split number from string

但对于我需要更新多个数字并在更新后将它们放回到正确位置的字符串的这种情况,则没有。

是否有更智能/更简单的方法来使用 JavaScript(Vanilla 或 jQuery)更新字符串中的所有数字?

最佳答案

您需要使用 String#replace使用匿名回调方法:

// Basic lerp
function lerp (min, max, amount) {
return Number(min + amount * (max - min));
}

var s = "-ms-transform: rotate(7deg);";
var max = 15, amount = 2;
console.log(
s.replace(/-?\d*[,.]?\d+/g, function(m) {
return lerp(Number(m), max, amount).toFixed(3);
})
);

模式是 /-?\d*[,.]?\d+/g 匹配多次出现的可选减号,0+ 数字后跟 ,. 然后是 1+ 位数字。

function(m){} 是作为替换参数传递给 String#replace 方法的匿名回调方法,其中值可以传递给其他方法。

关于javascript - 使用 JavaScript 更新字符串中的所有数字?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41728430/

28 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com