美文网首页react-native
数组、字符串的一些操作

数组、字符串的一些操作

作者: m_麻 | 来源:发表于2019-03-11 16:58 被阅读0次

    字符串
    1.获取:
    substring:返回位于string对象中指定位置的字符串
    substring(start,end);

    const imageData='aaaaaaaaaimgs0bbbbbbb';
    const search = 'imgs0';
    const start = imageData.indexOf(search); // 获取字符串的开始位置
    const result = imageData.substring(start, start + search.length + 1); // 截取字符串
    

    substr:返回一个从指定位置开始的指定长度的字符串
    substr(start,[length]);

    var string0="sss.sscdyfasdfdgfg";//sscdy获取
    var result=string0.substr(4,5);
    

    2.查找
    indexOf(string):string在父字符串中首次出现的位置,从0开始,若没有则返回-1;
    3.获取指定字符前面和后面的字符串

    /*
     description 字符串;
     search 指定字符;
     split(),用于把一个字符串分割成字符串数组;
     split(search)[0],读取数组中索引为0的值(第一个值),所有数组索引默认从0开始;
     */
    let description = 'aaaaaaaaaa:bbbbbbbb:ccccccccssss';
     const search = ':';
            if (description) {
                const start = description.indexOf(search); //获取:的位置
                let summary = description.split(search)[0]; //:前的字符
                let result = description.substring(start + 1,  description.length); // 截取第一个:后面的所有字符,即根据某个关键字截取关键字之后的所有字符
            }
    

    数组
    1.判断数组中是否包含某元素

    /*array.indexOf(item,start) 
    参数: 
    item:必须。查找的元素。 
    start:可选的整数参数。规定在字符串中开始检索的位置。它的合法取值是 0 到 stringObject.length - 1。如省略该参数,则将从字符串的首字符开始检索。
    */
    if(arr.indexOf(某元素) > -1){
    //则包含该元素
    }
    注:string.indexOf()返回某个指定的字符串值在字符串中首次出现的位置
    

    2.splice() 向数组中增加、删除某个元素

    var fruits = ["Banana", "Orange", "Apple", "Mango"];
    fruits.splice(2,0,"Lemon","Kiwi"); //从下标为2处开始增加,删除的数目为0  输出结果为Banana,Orange,Lemon,Kiwi,Apple,Mango
    

    3.slice()从已有的数组中返回指定的元素

    slice(start,end)  //返回一个新数组,从start开始,end结束
    //start、end可以为负数,表示从数组的末尾开始算起。end可以省略,若省略则表示从start到数组末尾的所有数据
    

    与splice()区别:
    slice()返回的是数组的副本,不会改变原数组。
    splice()会直接在原数组上面做出改变,会该改变原数组,且能够实现删除、增加等其他操作。
    4.数组深拷贝
    listView的sourceData不变化时,不会重新触发render,因为sourceData需要进行深拷贝

    const [...newData] = this.TagStore.data;
    this.TagStore.data = newData;
    
    forEach(this.data, (data) => {
                    data.read = true;
                });
     this.data = toJS(this.data).slice();
    

    数组与字符串之间的转化

    //数组转换字符串:join,将数组用某个字符连接成字符串
    let additionalDevices=[1,2,3,4,5];
    let additional_devices=additionalDevices.join(',');//'1,2,3,4,5'
    
    //字符串转数组,splict,将字符串按某个字符切割成若干个字符,并以数组形式返回
    var s = "abc,abcd,aaa";
    ss = s.split(",");// 在每个逗号(,)处进行分解  ["abc", "abcd", "aaa"]
    var s1 = "helloworld";
    ss1 = s1.split('');  //["h", "e", "l", "l", "o", "w", "o", "r", "l", "d"]
    

    获取对象的key,将其保存为数组

    const skills ={'数据分析': '2', '产品运营': '2', '项目管理': '3', '产品设计': '2', '教育': '1'}
     const data = Object.keys(skills);//[数据分析,产品运营,项目管理,产品设计,教育]
    

    参考资源:
    js实现截取或查找字符串中的子字符串
    js获取指定字符前/后的字符串简单实例
    js数组与字符串的相互转换方法

    相关文章

      网友评论

        本文标题:数组、字符串的一些操作

        本文链接:https://www.haomeiwen.com/subject/gimvpqtx.html