Node Buffer 利用 slice + indexOf 生成 split 方法
生活随笔
收集整理的這篇文章主要介紹了
Node Buffer 利用 slice + indexOf 生成 split 方法
小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.
demo?
let buf = Buffer.from('你你我們我你們'); Buffer.prototype.split = function (seq) {let arr=[];let len = Buffer.from(seq).length // console.log(len);let index= 0; //開始的長度 // console.log(this.toString());let target = this.indexOf(seq); // console.log(target); //輸出找到目標(biāo)之前的長度while(-1!=(current=this.indexOf(seq,index))) {arr.push(this.slice(index,current))index= current + len; //下次查找的長度應(yīng)該是目標(biāo)之前的長度 + 目標(biāo)的長度 }arr.push(this.slice(index))// index= target + len; //下次查找的長度應(yīng)該是目標(biāo)之前的長度 + 目標(biāo)的長度return arr.toString(); } console.log(buf.split('我'))輸出:
你你,們,你們 先得出 我們要分隔的字符串 的長度 Buffer.from(seq).length我們要返回的是一個數(shù)組 所以先聲明數(shù)組為空
let arr=[];return arr.toString();開始分割時長度為 0?
let index= 0; //開始的長度indexOf() 方法可返回某個指定的字符串值在字符串中首次出現(xiàn)的位置。
this.indexOf(seq,index)當(dāng)前的位置?
current=this.indexOf(seq,index)下次要開始查找的位置?
當(dāng)前的位置 +? 查找字符串的 長度?
current + len;做一個判斷 如果 查找到我們傳入的字符串 我們就將 查找到的目標(biāo)之前的 字符串添加到數(shù)組里面
while(-1!=(current=this.indexOf(seq,index))) {arr.push(this.slice(index,current))index= current + len; //下次查找的長度應(yīng)該是目標(biāo)之前的長度 + 目標(biāo)的長度}?截取字符串
this.slice(index,current)截取的是每次判斷的 目標(biāo)的 之前的?
?
轉(zhuǎn)載于:https://www.cnblogs.com/guangzhou11/p/11382086.html
總結(jié)
以上是生活随笔為你收集整理的Node Buffer 利用 slice + indexOf 生成 split 方法的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: ecshop 整合 QQ登陆 和 支付宝
- 下一篇: 关于ASP.Net的导入导出的[转]