问答

js for循环过滤改造对象

作者:admin 2021-05-09 我要评论

原始对象↓ let obj1 = [{name:'蔬菜-1',id:'123'}, {name:'蔬菜-2',id:'122'}, {name:'新鲜蔬菜',id:'112'}, {name:'劣质苹果',id:'114'}, {name:'苹果-新增',i...

在说正事之前,我要推荐一个福利:你还在原价购买阿里云、腾讯云、华为云服务器吗?那太亏啦!来这里,新购、升级、续费都打折,能够为您省60%的钱呢!2核4G企业级云服务器低至69元/年,点击进去看看吧>>>)

原始对象↓

let obj1 = [{name:'蔬菜-1',id:'123'},
            {name:'蔬菜-2',id:'122'},
            {name:'新鲜蔬菜',id:'112'},
            {name:'劣质苹果',id:'114'},
            {name:'苹果-新增',id:'115'},
            {name:'苹果-优质',id:'116'},
            {name:'香蕉',id:'106'},
            {name:'梨子',id:'156'}]

期待的效果↓

let result = [{name:'蔬菜',id:'123'},
              {name:'苹果',id:'114'},
              {name:'香蕉',id:'106'},
              {name:'梨子',id:'156'}]

也就是如果name里面有相同的字符,改造后的name就是那个相同的字符,其余的去掉,然后id的话就用在前的第一个就行,没有相同的话就一起遍历到result里面,这该怎么写呢

不知道我的问题描述是否清晰,还请各位大神指教,小弟感激不尽!!

###

这个简单,遍历一遍用map存起来,最后转数组就行,给你写个伪代码

const result = new Map()
obj1.forEach(item => {
  const name = item.name.split('-')[0]
  if (!result.has(name)) {
    result.set(name, { name, id: item.id })
  }
})
return [result.values()]
###

规约规则明确的情况下,比较好处理。不过目前的归约规则是部分字符匹配……我只能给我点参考文章:

你还可以自己上网去搜,以及搜 Java 或者 JavaScript 别人实现出来的库

###

这个其实不简单,因为命名很不规范,一个方法是有一个规范名字典,然后去匹配最早能全包含的项目生成。

但这个字典的产生也是一个麻烦事情,如果仅仅是根据数据本身来产生,是很麻烦的。

你采纳的答案中只考虑了用短横线分割的情况,它对 劣质苹果 其实是不能提取的。

版权声明:本文转载自网络,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。本站转载出于传播更多优秀技术知识之目的,如有侵权请联系QQ/微信:153890879删除

相关文章
  • app内的web页面,img路径对,但是不显

    app内的web页面,img路径对,但是不显

  • 如何做下载功能?

    如何做下载功能?

  • 复杂正则表达式,实现思路

    复杂正则表达式,实现思路

  • vue一段简单的代码出现奇怪的问题?

    vue一段简单的代码出现奇怪的问题?

腾讯云代理商
海外云服务器