javascript 数组循环-在 JavaScript 上将字符串转换为字段的 6 种方法

回复下方公众号【面试指南】即可获取为您整理的107页后端笔试题。

‍‍

链表是 JavaScript 中最强大的数据结构,我发现自己通过将字符串转换为链表来解决许多算法。 所以我想到结合和比较做同一件事的各种方法。 ‍

从字符串到链表的转换总是使用 split() 方法来完成,在 ES6 之后,我们可以使用很多工具来完成同样的事情。 让我们逐一讨论每种方法,并讨论每种方法的异同。

1.使用.split(''):

数组循环方法_javascript 数组循环_数组循环右移

split() 是一种字符串方法,它将字符串拆分为具有有序模式列表的字段。 这是 ES6 的方式,也是完成工作的最简洁的方式。

////* Seperate string by space character(' ') *////

const myFavShow = 'The Office';
const myFavShowArray = myFavShow.split('');
console.log(myFavShowArray) //['T''h''e'' ''O''f''f''i''c''e']

这些方法的另一个优点是我们可以用字符或空格分隔字符串。 下面是我们如何做到这一点的示例。

////* Seperate string by whitespace(' ') *////
const myFavShow = 'The Office';
const myFavShowArray = myFavShow.split(' ');
console.log(myFavShowArray) //['The''Office']


////* Seperate string by a character '-' *////
const favDialogue = 'Thats-what-she-said';
const favDialogueArr = favDialogue.split('-');
console.log(favDialogueArr) //['Thats''what''she''said']

它还适用于正则表达式,您可以在此处找到 split() 的完整文档。

这些方法完美地将字符串元素分离到链表中,但它有其局限性。

注意:此方法不适用于不常见的 Unicode 字符。 此方法返回字符的 Unicodejavascript 数组循环,而不是实际字符,这可能会使我们的工作稍微复杂一些,但 MDN 文档已更新,因此如果我们只包含 u 标志,我们就可以使其与 Unicode 一起使用。

javascript 数组循环_数组循环右移_数组循环方法

"".split(/(?:)/); // [ "ud83d""ude04""ud83d""ude04" ]
"".split(/(?:)/u); // [ """" ]

2. 使用扩展句型([…str])

这是ES2015的一个特性,使得转换变得非常容易。

const myFavShow = 'The Office'

const myFavShowArray = [...myFavShow]

console.log(myFavShowArray) 
// ['T''h''e'' ''O''f''f''i''c''e']

这也有助于清除我们在 split() 中的限制,考虑下面的示例javascript 数组循环,我们可以使用这些技巧轻松分割任何字符。

const animal = ''
const animalArr = [...animal]
console.log(animalArr) // ['''']

3.使用Array.from(str):

数组中, from() 方法从可迭代或类似字段的对象创建一个新的浅复制 Array 实例。

const myFavShow = 'The Office'

const myFavShowArray = Array.from(myFavShow);

console.log(myFavShowArray) 
// ['T''h''e'' ''O''f''f''i''c''e']
这种方法在处理不常见的字符时不会引起任何问题。
const str = ''
const arr = Array.from(str)
console.log(arr)


// ['''']

4.使用Object.assign([],str)

allocate() 方法将一个或多个源对象的所有属性复制到目标对象。 然而,关于这些技术有两点需要记住。 一是是哪个对象,二是assign()复制属性值称为深复制。 在使用此方法之前必须牢记这一点。

const myFavShow = 'The Office'

const myFavShowArray = Object.assign([], myFavShow);

console.log(myFavShowArray) 
// ['T''h''e'' ''O''f''f''i''c''e']

另一个是我们有与 split() 方法相同的麻烦:它无法分隔不寻常的字符(我们看到的是 Unicode 而不是实际字符)。

const s = ''
const a = Array.from(s)
console.log(a) // ['''']

javascript 数组循环_数组循环右移_数组循环方法

5. 使用老式方式(forloop 和 array.push())

事实上,我们有很多选择可以使用,但我不得不提一下这些老式的方法,我们使用 for 循环和链表 Push() 来推送字符串的元素。

这不是最简洁的方法,但如果您想远离 JavaScript 不断变化的复杂性,那么绝对值得一提(尽管我更喜欢其他形式)。

const s = 'the office';
const a = [];
for (const s2 of s) {
   a.push(s2);
}
console.log(a); // ['t''h''e'' ''o''f''f''i''c''e']

据悉,它对于不常见(Unicode)字符也能很好地工作。 请参阅下面的反例。

const s = '';
const a = [];
for (const s2 of s) {
   a.push(s2);
}
console.log(a); //['''''''''''']

6.使用Array.prototype.slice.call('string')

const favShow = Array.prototype.slice.call("The Office!");
console.log(favShow); //['T''h''e'' ''O''f''f''i''c''e''!']

该方法也存在与 split() 方法相同的问题,所以使用时要小心。

console.log(favShow); //['uD83D''uDE04''uD83D''uDE04'const favShow = Array.prototype.slice.call("The Office!");

结尾-

近期新课程:

HTML5+CSS基础|JavaScript|Vue2.0+Vue3.0|陌陌小程序|陌陌公众号开发|Node.js|node.JS前端|React基础知识|React项目