如何在React Native中订购数组?

时间:2019-01-21 14:31:05

标签: reactjs native

我必须订购

("Forecast":["WP17 - CO746U100 - Wenceslao Escalante --- Telefonia - Implementaciones","WP19 - CO804U100 - Viamonte Nuevo --- Telefonia - Implementaciones","WP18 - CO663U200 - Corral de Bustos 2 --- Telefonia - Implementaciones","WP22 - MBA205 - Olavarria 2 --- Telefonia - Integraciones","WP23 - MC1165 - Martinez 4 --- Telefonia - Integraciones","WP26 - MC1881 - Bajo Flores 2 --- Telefonia - Integraciones","WP12 - FD454 - Shopping Mendoza --- Telefonia - Implementaciones","WP65 - TEST1 - TEST-TASK --- Telefonia - Integraciones","WP25 - MC1510 - Nunez 4 Av Congreso --- Telefonia - Integraciones","WP1 - UFO555 - Villa Maria --- Telefonia - Implementaciones","WP28 - MFO066 - CAC Formosa --- Telefonia - Integraciones","WP70 - 4312341 - sarasa --- Telefonia - Integraciones","WP71 - 54325 - sarasa2 --- Telefonia - Integraciones","WP75 - 00001 - Complejo Capitalinas --- Obras Civiles","WP76 - 00002 - Mejora de la Ca\u00f1ada --- Obras Civiles","WP32 - MCO800 - Unquillo Norte Nuevo --- Telefonia - Implementaciones","WP33 - MCO817 - Hospital Privado Nuevo --- Telefonia - Implementaciones","WP34 - LTF039 - Ushuaia Paseo del Fuego --- Telefonia - Implementaciones","WP36 - LSJ062 - San Juan UMTS 2 --- Telefonia - Implementaciones","WP37 - LCO261 - ZIPOLI NUEVO --- Telefonia - Implementaciones","WP63 - 7878 - SIAM SA --- Telefonia - Implementaciones","WP64 - MCF162 - Kansas Acassuso Test --- Telefonia - Implementaciones","WP69 - 11111 - Nueva Tare --- Telefonia - Implementaciones"],) 

正如所说的那样,有工具,积分和欧普拉。

代码:

  let ObrasV = []
  let ImplementacionesV = []
  let IntegracionesV = []

  if(this.state.dataSource){
    this.state.dataSource.forEach(function(DATA) {
      if(/^Integraciones/.test(DATA)) {
        IntegracionesV = IntegracionesV.concat(DATA)      
      }
      if(/^Implementaciones/.test(DATA)) {
        ImplementacionesV = ImplementacionesV.concat(DATA)
      }
      if(/^Obras/.test(DATA)) {
        ObrasV = ObrasV.concat(DATA)
      }
    })
    this.setState({
      Integraciones: IntegracionesV,
      Implementaciones: ImplementacionesV,
      Obras: ObrasV,
    })
    } 

我是新来的,所以我会尽我所能?

2 个答案:

答案 0 :(得分:1)

您可以混合使用reducefilterincludes来实现它

const data = ["WP17 - CO746U100 - Wenceslao Escalante --- Telefonia - Implementaciones", "WP19 - CO804U100 - Viamonte Nuevo --- Telefonia - Implementaciones", "WP18 - CO663U200 - Corral de Bustos 2 --- Telefonia - Implementaciones", "WP22 - MBA205 - Olavarria 2 --- Telefonia - Integraciones", "WP23 - MC1165 - Martinez 4 --- Telefonia - Integraciones", "WP26 - MC1881 - Bajo Flores 2 --- Telefonia - Integraciones", "WP12 - FD454 - Shopping Mendoza --- Telefonia - Implementaciones", "WP65 - TEST1 - TEST-TASK --- Telefonia - Integraciones", "WP25 - MC1510 - Nunez 4 Av Congreso --- Telefonia - Integraciones", "WP1 - UFO555 - Villa Maria --- Telefonia - Implementaciones", "WP28 - MFO066 - CAC Formosa --- Telefonia - Integraciones", "WP70 - 4312341 - sarasa --- Telefonia - Integraciones", "WP71 - 54325 - sarasa2 --- Telefonia - Integraciones", "WP75 - 00001 - Complejo Capitalinas --- Obras Civiles", "WP76 - 00002 - Mejora de la Ca\u00f1ada --- Obras Civiles", "WP32 - MCO800 - Unquillo Norte Nuevo --- Telefonia - Implementaciones", "WP33 - MCO817 - Hospital Privado Nuevo --- Telefonia - Implementaciones", "WP34 - LTF039 - Ushuaia Paseo del Fuego --- Telefonia - Implementaciones", "WP36 - LSJ062 - San Juan UMTS 2 --- Telefonia - Implementaciones", "WP37 - LCO261 - ZIPOLI NUEVO --- Telefonia - Implementaciones", "WP63 - 7878 - SIAM SA --- Telefonia - Implementaciones", "WP64 - MCF162 - Kansas Acassuso Test --- Telefonia - Implementaciones", "WP69 - 11111 - Nueva Tare --- Telefonia - Implementaciones"]

const result = ['Implementaciones', 'Integraciones', 'Obras']
    .reduce((total, category) => ({
        ...total,
        [category]: data.filter(line => line.includes(category))
    }), {})

console.log(result)

结果对象将包含3个包含所有数据的数组

使用forEach易于阅读的实现:

const data = ["WP17 - CO746U100 - Wenceslao Escalante --- Telefonia - Implementaciones", "WP19 - CO804U100 - Viamonte Nuevo --- Telefonia - Implementaciones", "WP18 - CO663U200 - Corral de Bustos 2 --- Telefonia - Implementaciones", "WP22 - MBA205 - Olavarria 2 --- Telefonia - Integraciones", "WP23 - MC1165 - Martinez 4 --- Telefonia - Integraciones", "WP26 - MC1881 - Bajo Flores 2 --- Telefonia - Integraciones", "WP12 - FD454 - Shopping Mendoza --- Telefonia - Implementaciones", "WP65 - TEST1 - TEST-TASK --- Telefonia - Integraciones", "WP25 - MC1510 - Nunez 4 Av Congreso --- Telefonia - Integraciones", "WP1 - UFO555 - Villa Maria --- Telefonia - Implementaciones", "WP28 - MFO066 - CAC Formosa --- Telefonia - Integraciones", "WP70 - 4312341 - sarasa --- Telefonia - Integraciones", "WP71 - 54325 - sarasa2 --- Telefonia - Integraciones", "WP75 - 00001 - Complejo Capitalinas --- Obras Civiles", "WP76 - 00002 - Mejora de la Ca\u00f1ada --- Obras Civiles", "WP32 - MCO800 - Unquillo Norte Nuevo --- Telefonia - Implementaciones", "WP33 - MCO817 - Hospital Privado Nuevo --- Telefonia - Implementaciones", "WP34 - LTF039 - Ushuaia Paseo del Fuego --- Telefonia - Implementaciones", "WP36 - LSJ062 - San Juan UMTS 2 --- Telefonia - Implementaciones", "WP37 - LCO261 - ZIPOLI NUEVO --- Telefonia - Implementaciones", "WP63 - 7878 - SIAM SA --- Telefonia - Implementaciones", "WP64 - MCF162 - Kansas Acassuso Test --- Telefonia - Implementaciones", "WP69 - 11111 - Nueva Tare --- Telefonia - Implementaciones"]

const result = {};

['Implementaciones', 'Integraciones', 'Obras'].forEach(category => {
    result[category] = data.filter(line => line.includes(category))
})

console.log(result)

答案 1 :(得分:0)

只需注意new RegExp()并避免使用^

let ObrasV = []
  let ImplementacionesV = []
  let IntegracionesV = []

  if(this.state.dataSource){
    this.state.dataSource.forEach(function(DATA) {
      if(new RegExp(/Integraciones/).test(DATA)) {
        IntegracionesV = IntegracionesV.concat(DATA)      
      }
      if(new RegExp(/Implementaciones/).test(DATA)) {
        ImplementacionesV = ImplementacionesV.concat(DATA)
      }
      if(new RegExp(/Obras/).test(DATA)) {
        ObrasV = ObrasV.concat(DATA)
      }
    })
    this.setState({
      Integraciones: IntegracionesV,
      Implementaciones: ImplementacionesV,
      Obras: ObrasV,
    })
    }