请教一个 js 字符串问题。。 - V2EX
V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
请不要在回答技问题时复制粘贴 AI 生成的内容
muunala10221
V2EX    程序员

请教一个 js 字符串问题。。

  •  
  •   muunala10221 2021-03-09 18:33:29 +08:00 1935 次点击
    这是一个创建于 1687 天前的主题,其中的信息可能已经有所发展或是发生改变。

    一个数组 里面的元素都是字符串,如果某一个元素中全是 \n 那么移除掉这个元素,只能想到遍历数组 然后遍历字符串,但性能太低下了 有什么比较好的办法吗 感谢

    66beta
        1
    66beta  
       2021-03-09 18:35:27 +08:00
    遍历数组没问题,为什么要遍历字符串?
    '1\n2\n3'.replace(/\n/g, '')
    muunala10221
        2
    muunala10221  
    OP
       2021-03-09 18:37:02 +08:00
    @66beta 感谢回复,全是 \n 的才处理 像这种'1\n2\n3'不处理的哦 例如 ['1\n2', '\n\n\n', '\n'] 数组 1 和 2 要处理
    muunala10221
        3
    muunala10221  
    OP
       2021-03-09 18:45:11 +08:00
    想到一个思路 也是遍历字符串 如果遍历到的字符 不是 \n 就跳过 能节省点性能 不知道还有没有更好的办法
    g1f9
        4
    g1f9  
       2021-03-09 18:45:28 +08:00 via Android
    trim 一下判空怎么样。至于性能,是你觉得慢,还是实际业务因为这个问题没达到要求
    tnjin
        5
    tnjin  
       2021-03-09 18:48:43 +08:00
    遍历数组,然后用正则判断当前元素是否全为\n,是就移除,不是就不移除。
    var reg = new RegExp("^\n*$");
    zictos
        6
    zictos  
       2021-03-09 18:48:56 +08:00
    var str = "\n\n\n\n\n";
    var n = str.search(/^\n+$/);

    如果 n 等于 0,就说明字符串全是\n
    Building
        7
    Building  
       2021-03-09 18:53:59 +08:00 via iPhone
    这样循环处理其实没有什么性能问题,毕竟都是在内存上操作,字符串也是有长度限制的,你再匹配或者替换一下字符串反而更复杂。
    66beta
        8
    66beta  
       2021-03-09 18:55:42 +08:00
    思想不滑坡,办法总有多 if (str.replace(/\n/g, '') !== '')
    Vegetable
        9
    Vegetable  
       2021-03-09 19:02:23 +08:00
    没什么好办法,循环+及时跳出就到头了,再搞下去在 jit 面前也未必有意义。
    autoxbc
        10
    autoxbc  
       2021-03-09 19:20:14 +08:00
    遇到性能问题再谈性能优化
    ljpCN
        11
    ljpCN  
       2021-03-09 20:28:17 +08:00
    ['1\n2', '\n\n\n', '\n'].filter((s) => !/^\n*$/.test(s));
    Reapper
        12
    Reapper  
       2021-03-10 09:10:02 +08:00
    数组肯定要遍历,但是字符串可以用正则啊!
    if(!'some character'.match(/[^\n]/)){ //记录序号,最后再删除 }
    muunala10221
        13
    muunala10221  
    OP
       2021-03-10 09:48:43 +08:00
    muunala10221
        14
    muunala10221  
    OP
       2021-03-10 09:49:52 +08:00
    @g1f9 业务是 web 上的 sql 编辑,就是可能会有 N 个库 每个库下有可能 N 个表 N 个视图 N 个 trigger...然后每个表下语句可能很大 算是我个人觉得会导致性能问题
    g1f9
        15
    g1f9  
       2021-03-10 10:18:30 +08:00 via Android
    @muunala10221 那还是建议先做,有瓶颈了再优化,从各个端口进行尝试。比如在存数据的时候,无意义的数据就不存之类的
    muunala10221
        16
    muunala10221  
    OP
       2021-03-10 10:32:25 +08:00
    @g1f9 OK 感谢
    muunala10221
        17
    muunala10221  
    OP
       2021-03-10 10:58:46 +08:00
    @zictos 感谢 解决了我的问题
    关于     帮助文档     自助推广系统     博客     API     FAQ     Solana     3518 人在线   最高记录 6679       Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 28ms UTC 10:39 PVG 18:39 LAX 03:39 JFK 06:39
    Do have faith in what you're doing.
    ubao msn snddm index pchome yahoo rakuten mypaper meadowduck bidyahoo youbao zxmzxm asda bnvcg cvbfg dfscv mmhjk xxddc yybgb zznbn ccubao uaitu acv GXCV ET GDG YH FG BCVB FJFH CBRE CBC GDG ET54 WRWR RWER WREW WRWER RWER SDG EW SF DSFSF fbbs ubao fhd dfg ewr dg df ewwr ewwr et ruyut utut dfg fgd gdfgt etg dfgt dfgd ert4 gd fgg wr 235 wer3 we vsdf sdf gdf ert xcv sdf rwer hfd dfg cvb rwf afb dfh jgh bmn lgh rty gfds cxv xcv xcs vdas fdf fgd cv sdf tert sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf shasha9178 shasha9178 shasha9178 shasha9178 shasha9178 liflif2 liflif2 liflif2 liflif2 liflif2 liblib3 liblib3 liblib3 liblib3 liblib3 zhazha444 zhazha444 zhazha444 zhazha444 zhazha444 dende5 dende denden denden2 denden21 fenfen9 fenf619 fen619 fenfe9 fe619 sdf sdf sdf sdf sdf zhazh90 zhazh0 zhaa50 zha90 zh590 zho zhoz zhozh zhozho zhozho2 lislis lls95 lili95 lils5 liss9 sdf0ty987 sdft876 sdft9876 sdf09876 sd0t9876 sdf0ty98 sdf0976 sdf0ty986 sdf0ty96 sdf0t76 sdf0876 df0ty98 sf0t876 sd0ty76 sdy76 sdf76 sdf0t76 sdf0ty9 sdf0ty98 sdf0ty987 sdf0ty98 sdf6676 sdf876 sd876 sd876 sdf6 sdf6 sdf9876 sdf0t sdf06 sdf0ty9776 sdf0ty9776 sdf0ty76 sdf8876 sdf0t sd6 sdf06 s688876 sd688 sdf86