Конвертировать функцию JavaScript ES6 в ES3 - PullRequest
1 голос
/ 04 апреля 2019

У меня есть массив, который я успешно преобразую в строковый формат с помощью функции EcmaScript-6.Тем не менее, как я могу сделать это с помощью EcmaScript-3?Принимающей конечной точке требуется функция ES3.

Исходный массив:

formdata: [
    1: {name: "gender", value: "F", focus: 0, type: "radio"}
    2: {name: "firstname", value: "empty", focus: 0, type: "text"}
    3: {name: "lastname", value: "empty", focus: 0, type: "text"}
    4: {name: "birthday", value: "empty", focus: 0, type: "text"}
    5: {name: "street", value: "empty", focus: 0, type: "text"}
    6: {name: "streetNo", value: "empty", focus: 0, type: "text"}
]

Требуемый формат строки

let formdata = gender.radio|F|0;firstName.text|empty|1;lastName.text|empty|0;street.text|empty|0;houseNumber.text|empty|0;zip.text|empty|0;city.text|empty|0;country.select-one|de|0;birthdate-day.text|empty|0;birthdate-month.text|empty|0;birthdate-year.text|empty|0;email.email|empty|0;code.text|filled_out|0

Мое рабочее решение с ES6:

let res = formdata.map(({name,value,focus,type}) => `${name}.${type}|${value}|${focus}`).join(';')

Мой подход к преобразованию в ES3:

var res = formdata.map(({name,value,focus,type}) { 
  ("name" + "." + "type" + "|" + "value" + "focus").join(;)
}

Это решение, очевидно, не работает иТакже я не уверен, является ли это действительно ES3 JavaScript.

Спасибо!

1 Ответ

3 голосов
/ 04 апреля 2019

Проблемы с вашей попыткой ES3:

  • Функция стрелки пропускает стрелку, но также является добавлением ES6 к синтаксису
  • .join(;) - недопустимый JavaScript..join(";") is.
  • синтаксис деструктурирования введен в ES6
  • .map введен в ES5
  • Вам нужен еще один "|"

Итак:

var formdata = [{name: "gender", value: "F", focus: 0, type: "radio"},{name: "firstname", value: "empty", focus: 0, type: "text"},{name: "lastname", value: "empty", focus: 0, type: "text"},    {name: "birthday", value: "empty", focus: 0, type: "text"},{name: "street", value: "empty", focus: 0, type: "text"},{name: "streetNo", value: "empty", focus: 0, type: "text"},];

var arr = [];
for (var i = 0; i < formdata.length; i++) {
    var elem = formdata[i];
    arr.push(elem.name + "." + elem.type + "|" + elem.value + "|" + elem.focus);
}
var str = arr.join(";");

console.log(str);
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...