通过call bind方法使字符串借用数组的方法

在JS中,数组的方法相比于字符串的方法更加丰富,多样性,那么如果字符串,类数组想用数组的方法,可以有以下的办法

字符串转换为数组

可以让字符串转换为数组操作,之后再将数组转为字符串。
转换为数组可以这样做:

	let str = 'HollowKnight'
	
	//1、直接使用解构的方式
	let arr1 = [...str]
	//2、使用Array.from 方法
	let arr2 = Array.from(str)
	//3、使用字符串split方法
	let arr3 = str.split('')
	//4、遍历字符串,遍历途中可以进行其他操作
	let arr4 = []
	for (let v of str) {
	  arr3.push(v)
	}

直接借用数组Array.prototype.方法

使用call改变this指向,让原本指向数组改为字符串

    let str = 'HollowKnight'

    //使用slice也可以直接将字符串分割
    let arr = Array.prototype.slice.call(str)

    //过滤
    let str1 = Array.prototype.filter.call(str, v => v == 'o').join('')
    //每个字符间加 |
    let str2 = Array.prototype.map.call(str, v => v + '|').join('')

注意:这里字符串能够用的方法都是不会改变原数组的方法,因为字符串是不能被更改的,如果使用push、pop、shift等会对原数组产生改变的方法,是不能用,会报错。

	let str = 'HollowKnight'
	let arr = Array.prototype.push.call(str, 1)
	// Uncaught TypeError: Cannot assign to read only property 'length' of object '[object String]'

利用Function.prototype.call.bind方法直接定义数组方法

Function.prototype.call.bind(Array.prototype.filter)
bind 让Array.prototype.filter 使用 call方法,后面的参数就可以在需要使用时在填入,不用每次都写那么长的代码

    let str = 'HollowKnight'

    let filter = Function.prototype.call.bind(Array.prototype.filter)

    str = filter(str, v => v == 'o').join('')
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值