替换数组中文本的简写
Short hand for replacing text in array
我有这个简单的代码
string = "google windows ico.Win10 ubuntu ico.Microsoft"
keysArray = string.split("+").filter(e => e);
for (let i = 0; i < keysArray.length; i++) {
keysArray[i] = keysArray[i].replace("ico.Win10", '<i class="fab fa-windows"></i>')
keysArray[i] = keysArray[i].replace("ico.Apple", '<i class="fab fa-apple"></i>')
keysArray[i] = keysArray[i].replace("ico.Android", '<i class="fab fa-android"></i>')
keysArray[i] = keysArray[i].replace("ico.Linux", '<i class="fab fa-linux"></i>')
keysArray[i] = keysArray[i].replace("ico.Ubuntu", '<i class="fab fa-ubuntu"></i>')
keysArray[i] = keysArray[i].replace("ico.Unity", '<i class="fab fa-unity"></i>')
keysArray[i] = keysArray[i].replace("ico.Snapchat", '<i class="fab fa-snapchat"></i>')
keysArray[i] = keysArray[i].replace("ico.Whatsapp", '<i class="fab fa-whatsapp"></i>')
keysArray[i] = keysArray[i].replace("ico.Instagram", '<i class="fab fa-instagram"></i>')
keysArray[i] = keysArray[i].replace("ico.Google", '<i class="fab fa-google"></i>')
keysArray[i] = keysArray[i].replace("ico.Microsoft", '<i class="fab fa-microsoft"></i>')
}
console.log(keysArray)
这里我将字符串转换为数组并过滤掉所有空字符串。
如果文本存在,则替换数组的每个项目中的文本
但是当有很多文本要替换时,我不得不调用 .replace
函数数千次。有没有一种方法可以以礼貌的方式做同样的事情?
我建议查找 table
const icons = {
"Win10": "fa-windows",
"Apple": "fa-apple",
"Android": "fa-android",
"Linux": "fa-linux",
"Ubuntu": "fa-ubuntu",
"Unity": "fa-unity",
"Snapchat": "fa-snapchat",
"Whatsapp": "fa-whatsapp",
"Instagram": "fa-instagram",
"Google": "fa-google",
"Microsoft": "fa-microsoft"
}
const string = "google windows ico.Win10 ubuntu ico.Microsoft"
const keysArray = string
.split(" ")
.map(key => key.startsWith('ico.') ? `<i class="fab ${key.replace(key, icons[key.split(".")[1]])}"></i>` : key)
.join(" ");
console.log(keysArray)
如果我们绝对确定输入与图标匹配,我们甚至不需要它 - 这里 Win10 会失败,但其余工作
const string = "google windows ico.Windows ubuntu ico.Microsoft"
const keysArray = string
.split(" ")
.map(key => key.startsWith('ico.') ?
`<i class="fab fa-${key.split(".")[1].toLowerCase()}"></i>` : key)
.join(" ");
console.log(keysArray)
我有这个简单的代码
string = "google windows ico.Win10 ubuntu ico.Microsoft"
keysArray = string.split("+").filter(e => e);
for (let i = 0; i < keysArray.length; i++) {
keysArray[i] = keysArray[i].replace("ico.Win10", '<i class="fab fa-windows"></i>')
keysArray[i] = keysArray[i].replace("ico.Apple", '<i class="fab fa-apple"></i>')
keysArray[i] = keysArray[i].replace("ico.Android", '<i class="fab fa-android"></i>')
keysArray[i] = keysArray[i].replace("ico.Linux", '<i class="fab fa-linux"></i>')
keysArray[i] = keysArray[i].replace("ico.Ubuntu", '<i class="fab fa-ubuntu"></i>')
keysArray[i] = keysArray[i].replace("ico.Unity", '<i class="fab fa-unity"></i>')
keysArray[i] = keysArray[i].replace("ico.Snapchat", '<i class="fab fa-snapchat"></i>')
keysArray[i] = keysArray[i].replace("ico.Whatsapp", '<i class="fab fa-whatsapp"></i>')
keysArray[i] = keysArray[i].replace("ico.Instagram", '<i class="fab fa-instagram"></i>')
keysArray[i] = keysArray[i].replace("ico.Google", '<i class="fab fa-google"></i>')
keysArray[i] = keysArray[i].replace("ico.Microsoft", '<i class="fab fa-microsoft"></i>')
}
console.log(keysArray)
这里我将字符串转换为数组并过滤掉所有空字符串。 如果文本存在,则替换数组的每个项目中的文本
但是当有很多文本要替换时,我不得不调用 .replace
函数数千次。有没有一种方法可以以礼貌的方式做同样的事情?
我建议查找 table
const icons = {
"Win10": "fa-windows",
"Apple": "fa-apple",
"Android": "fa-android",
"Linux": "fa-linux",
"Ubuntu": "fa-ubuntu",
"Unity": "fa-unity",
"Snapchat": "fa-snapchat",
"Whatsapp": "fa-whatsapp",
"Instagram": "fa-instagram",
"Google": "fa-google",
"Microsoft": "fa-microsoft"
}
const string = "google windows ico.Win10 ubuntu ico.Microsoft"
const keysArray = string
.split(" ")
.map(key => key.startsWith('ico.') ? `<i class="fab ${key.replace(key, icons[key.split(".")[1]])}"></i>` : key)
.join(" ");
console.log(keysArray)
如果我们绝对确定输入与图标匹配,我们甚至不需要它 - 这里 Win10 会失败,但其余工作
const string = "google windows ico.Windows ubuntu ico.Microsoft"
const keysArray = string
.split(" ")
.map(key => key.startsWith('ico.') ?
`<i class="fab fa-${key.split(".")[1].toLowerCase()}"></i>` : key)
.join(" ");
console.log(keysArray)