• Проблема с типами при использовании useState, typescript/react?

    @disappearedstar
    Фронтенд-разработчик
    type AcceptedFile = {
      name: string;
      type: string;
    };
    ...
      const [files, setFiles] = useState<AcceptedFile[]>([]);
    ...
      const handleDrop = (acceptedFiles: AcceptedFile[]) => {
       setFiles((currentFiles) => {
         return isMultiple
          ? [...currentFiles, ...acceptedFiles]
          : [acceptedFiles[0]];
       });
      };
    Ответ написан
    1 комментарий
  • Как модифицировать массив?

    @vshvydky
    const arr = [
    { val: 1, from: 0, to: 25 }, 
    { val: 2, from: 9, to: 13 }, 
    { val: 3, from: 14, to: 20 }]
    const output = arr
        .map(el=>[el.from, el.to])
        .flat()
        .sort((a,b)=>a-b)
        .map((el, index, array)=>array[index+1] && [el, array[index+1]])
        .filter(el=>el)

    хотя я не учел пробел между 13 14 но он не укладывается в логику остального примера, короче пример кода думаю даст пояснение как можно работать с массивами
    Ответ написан
    1 комментарий
  • Как реализовать через HOC, react?

    rockon404
    @rockon404 Куратор тега React
    Frontend Developer
    Без параметров:
    const withSort = WrappedComponent => props => {
      return WrappedComponent ? <WrappedComponent {...props} /> : null;
    });

    Использование:
    export default withSort(Component);

    C параметрами:
    const withSort = (...params) => WrappedComponent => props => {
      // params usage
      return WrappedComponent ? <WrappedComponent {...props} /> : null;
    });

    Использование:
    export default withSort(param1, param2)(Component);
    Ответ написан
    1 комментарий
  • Паттерны программирования для react developer-а?

    rockon404
    @rockon404 Куратор тега React
    Frontend Developer
    Хорошо знать, что они есть и какие задачи решают. Стоит понимать, что JavaScript и, в частности, код React приложения, сильно далек от классического ООП и во многих классических паттернах тут нет необходимости. А что-то уже реализовано в браузерных API и библиотеках которые вы используете.
    В JavaScript и в React разработке используются свои паттерны и приемы. Просто вбейте в поисковике React patterns . Так же хорошо знать что такое принципы SOLID, DRY и прочее.
    Ответ написан
    2 комментария
  • Почему git rebase удаляет файлы?

    @sergey_kzn
    Подозреваю, что нужно понять как именно работает rebase.
    При выполнении git rebase master, git сделает так:
    • найдет начало текущей ветки
    • git checkout master
    • в цикле будет применять по одному коммиту от начала текущей ветки, до крайнего. Если будет конфликт, процесс встанет, гит предложит разрешить конфликт, и далее позволит продолжить.

    Это примерное поведение при rebase.
    В вашем же случае, подозреваю, есть конфликты, поэтому гит не доходит до тех коммитов, где появились нужные вам файлы. Если конфликт разрешить и сделать git rebase --continue процесс продолжится.
    Сам по себе rebase удаления каких либо файлов не подразумевает, только применение коммитов.

    А так верно заметили, что rebase уже опубликованной ветки делать не стоит.
    Ответ написан
    4 комментария
  • Как убрать из объекта пустые объекты, js?

    0xD34F
    @0xD34F Куратор тега JavaScript
    Собрать новый объект:

    const newData = Object
      .entries(data)
      .reduce((acc, [ k, v ]) => (v.length && (acc[k] = v), acc), {});

    Удалить свойства существующего:

    Object.keys(data).forEach(n => data[n].length || delete data[n]);

    Можно использовать Lodash.

    const newData = _.pickBy(data, n => n.length);
    
    // или
    
    _.each(data, (v, k) => v.length || delete data[k]);
    Ответ написан
    1 комментарий
  • Как убрать eslint warnings одной командой?

    rockon404
    @rockon404
    Frontend Developer
    Поставьте prettier.
    Добавьте его в .eslintrc:
    {
      "extends": [
        "airbnb",
        "prettier",
      ],
      "plugins": [
        "prettier"
      ],
      "parser": "babel-eslint"
    }


    Исправить код можно командой:
    prettier --write
    Ответ написан
    2 комментария
  • Почему ошибка при установке prettier?

    rockon404
    @rockon404
    Frontend Developer
    ставьте плагин eslint-plugin-react. Дополнительно если не установлены:
    eslint
    babel-eslint
    eslint-plugin-jsx-a11y
    eslint-plugin-import
    eslint-config-prettier
    eslint-config-airbnb
    eslint-plugin-prettier
    Добавляйте так:
    {
      "extends": [
        "airbnb",
        "prettier",
        "prettier/react"
      ],
      "plugins": [
        "prettier"
      ],
      "parser": "babel-eslint",
      "parserOptions": {
        "ecmaFeatures": {
          "jsx": true
        }
      },
      "env": {
        "browser": true,
        "node": true
      },
      "rules": {
        "no-plusplus": 0,
        "no-confusing-arrow": 0,
        "no-restricted-syntax": 0,
        "guard-for-in": 0,
        "class-methods-use-this": 0,
        "jsx-a11y/no-static-element-interactions": 0,
        "jsx-a11y/anchor-is-valid": 0,
        "react/no-danger": 0,
        "react/prop-types": 0,
        "react/jsx-filename-extension": 0,
        "react/jsx-curly-brace-presence": ["error", { "props": "never", "children": "never" }],
        "import/no-unresolved": ["error", { "commonjs": true }],
        "import/extensions": 0,
        "import/no-extraneous-dependencies": ["error", {"devDependencies": true}],
        "import/prefer-default-export": 0,
        "prettier/prettier": ["error", {
          "singleQuote": true,
          "trailingComma": "all"
        }]
      }
    }


    Правила настройте под себя.

    Если хотите precommit проверку, то поставьте lint-stаged и husky, и добавьте следующие строки в package.json:
    "scripts": {
        // ваши скрипты
        "precommit": "./node_modules/.bin/lint-staged",
      },
      "lint-staged": {
        "**/*.js": [
          "./node_modules/.bin/prettier --write",
          "./node_modules/.bin/eslint --fix",
          "./node_modules/.bin/stylelint './app/**/*.js'", // если используете  css in js
          "git add"
        ]
      },

    Теперь перед каждым вашим коммитом код будет приводиться в порядок на автомате если это возможно. И прерывать коммит ошибкой если нарушены правила.
    Ответ написан
  • Чем заменить null в массиве?

    lazalu68
    @lazalu68
    Salmon
    const types = [];
    types[2] = 'OPEN_MODAL';
    types[3] = 'CLOSE_MODAL';
    Ответ написан
    Комментировать
  • Ваша мнение о модульном react/redux?

    alexiusp
    @alexiusp
    senior frontend developer
    Мне кажется всё зависит от масштабов.
    Если у вас две-три странички в приложении, то делать для каждой кнопки и каждого компонента свои файлы с экшнами, редюсерами и стейтом - лишний гемор.
    А вот если приложение достаточно масштабное и хорошо делится на более-менее обособленные модули, то для этих модулей вполне логично сделать свои отдельные экшны, редюсеры и стейт, сложить всё это в отдельную папку, а в перспективе можно этот модуль и в отдельный бандл вынести и ленивую загрузку прикрутить.
    Нужно помнить, что программирование должно решать проблему сложности, т.е. уменьшать эту самую сложность. Если с увеличением файлов сложность растёт - вы что-то делаете не так.
    Ответ написан
    Комментировать
  • Ваша мнение о модульном react/redux?

    @hellpirat
    Full stack developer (Python/Django, React.js)
    Положительно отношусь и сам постепенно стараюсь перейти на модульную структуру. Стало немного больно прыгать по папкам.
    Например в стандартном подходе есть какая-то сущность Account. Это надо пойти в /actions/account.js /reducers/account.js /containers/Account/Account.jsx и тд.
    А в модульном проще открыть /Account/index.jsx reducer.js, action.js
    Ну это больше мое личное мнение и немного опыта :)
    Ну и конечно же многое зависит от проектов.
    Ответ написан
    4 комментария
  • Ваша мнение о модульном react/redux?

    @vshvydky
    Мне кажется неверным объединять компоненту с экшенрм, по крайней мере в моих проектах экшены переиспользуются разными компонениами, а это уже такой каши насоздает,ак что я считаю это плохим решением.
    Для себя я пришел к мысли не делить проект на компоненты и контейнеры ибо нефиг, там где компоненте нужен редас стейт и экшены я их просто подключаю и не пложу лишнин файлы и иерархию . Каждому свое.
    Ответ написан
    Комментировать
  • Ваша мнение о модульном react/redux?

    gadfi
    @gadfi
    https://gamega.org
    мне гораздо больше нравится статья вы не гугл
    имхо нет универсльаного решения для больших проектов
    если проект реально большой что его модули можно рассматривать как небольшие программы то почему бы нет
    кстати кто мешает в отдельном модуле делать папочки для компонентов, контейнеров, экшенов и редюсеров ?
    кстати контейнер как в тудулисте однозначное зло, лучше лишний раз наплодить конейнеров или чуть более умных компонентов чем прокидывать в компонент за 20 пропертей )

    для ряда проектов с общим кодом для react-native react я и вовсе думаю часть модулей выносить в npm модули, это пока мысли и не факт что так сделаю, но пока в голове кручу эту идею )
    это я к тому что не надейтесь найти серебряную пулю, слепо следовать архитектуре для которой нет даже официальных рекомендаций, не то что спецификаций, тем более на фронтенде не всегда хорошо )
    Ответ написан
    1 комментарий
  • Полноценный пример SSR для react/redux?

    Да состояние собирается на сервере для каждого клиента (request'a), скажем на уровне мидлвара мы собираем состояние (текущего авторизованного пользователя, какие-то другие глобальные данные), далее отрабатывает обработчик маршрута, мы получили данные какой-то страницы из бд и передали их как контекст, примерно так:
    import React from 'react';
    import { StaticRouter } from 'react-router'
    import { Provider } from 'react-redux'
    import ReactDOMServer from 'react-dom/server';
    
    import App from './client/components/App.jsx'
    
    ReactDOMServer.renderToString(
    	<Provider store={ReduxStore}>
    		<StaticRouter
    			location={Url}
    			context={Context}>
    			<App/>
    		</StaticRouter>
    	</Provider>
    );

    Где, ReduxStore сгенерированное нами глобальное состояние (redux) запроса, Url запрошенный урл, Context контекст (будет передано как this.props.staticContext в компонент). Реакт вытянет нужный контейнер роута (по вашим маршрутам в App) и передаст ему контекст, компонент рендерится исходя из полученных данных. Результатом работы метода renderToString будет html строка (размеченная реактом), которую мы шаблонизатором или как угодно впиливаем в блок моунта компонента (в верстке), дополнительно в шаблонизатор передаем сгенерированное состояние, в документации выглядит вот так:
    window.__PRELOADED_STATE__ = JSON.stringify(preloadedState || {}).replace(/</g, '\\u003c')

    Теперь что происходит после того как страница загрузилась и подхватились клиент-скрипты? Все просто мы подхватываем состояние из window.__PRELOADED_STATE__ и вообщем-то все, глобальное состояние передано, компонент уже отрендерен, стоит учитывать что результаты при клиент-рендере и при сервер-рендере должны быть всегда одинаковыми, так же не использовать методы доступные браузеру, но не доступные серверу (на уровне моунта и первого рендера) и хорошенько следить за своим кодом в плане памяти, иначе при какой-либо утечке, память на сервере не будет вычищаться после каждого рендера.
    ---
    Как-то так, надеюсь помог, хотя там еще довольно много заковык
    Ответ написан
    20 комментариев
  • Как достать данные с модуля который дергает базу, nodejs/express?

    @de1m
    Можено сделать с callback'ом
    var getDataFromDatabase = function () {
      var arr = []
      var con = mysql.createConnection(conf.config);
      con.connect(function (err) {
    
        if(err) throw err;
        con.query("SELECT DID, DName FROM Device")
        .on('result', function (data) {
          arr.push(data)
        })
        .on('end', function () {
          return callback(null, arr);
        })
        .on('error', function(err){
            return callback (err, null);
        });
    }
    
    module.exports = {
        getDataFromDatabase
    }


    Потом вызываете
    var fromDB = require(./modulName);
    fromDB.getDataFromDatabase(function(err, result){
        if(err){
            console.log(err);
        } else {
            console.log(result);
        }
    })


    Можно сделать через промис
    var getDataFromDatabase = function (callback) {
        return new Promise((resolve, reject) => {
            var arr = []
            var con = mysql.createConnection(conf.config);
            con.connect(function (err) {
    
                if (err) throw err;
                con.query("SELECT DID, DName FROM Device")
                    .on('result', function (data) {
                        arr.push(data)
                    })
                    .on('end', function () {
                        return resolve(arr);
                    })
                    .on('error', function (err) {
                        return reject(err);
                    })
            });
        })
    }
    
    module.exports = {
        getDataFromDatabase
    }

    Вызов
    var fromDB = require("./modulName");
    fromDB.getDataFromDatabase()
        .then(result =>{
            console.log(result);
        },(err)=>{
            console.log(err);
        })


    Ну и через асинхрнные функции тоже
    var getDataFromDatabase = async function (callback) {
        return new Promise((resolve, reject) => {
            var arr = []
            var con = mysql.createConnection(conf.config);
            con.connect(function (err) {
    
                if (err) throw err;
                con.query("SELECT DID, DName FROM Device")
                    .on('result', function (data) {
                        arr.push(data)
                    })
                    .on('end', function () {
                        return callback(null, arr);
                    })
                    .on('error', function (err) {
                        return callback(err, null);
                    })
            });
        })
    }
    
    module.exports = {
        getDataFromDatabase
    }

    Вызов
    var fromDB = require("./modulName");
    var test = await fromDB.getDataFromDatabase();


    Возможно я где-то ошибся, писал по памяти.
    Вот тут я почти всё писал на асинхронных функциях может быть что-то полезное найдёте.
    Ответ написан
    2 комментария
  • Фильтрация большого количества данных react/redux?

    @vaskadogana
    Frontend developer
    я так делаю
    return searchValue.indexOf(searchQuery) !== -1;
    Ответ написан
    Комментировать
  • Фильтрация большого количества данных react/redux?

    @197291
    Я бы предложил несколько способов оптимизации.
    1) Использовать стандартный цикл for с кэшированием длины массива. Вид ухудшится, но по скорости выиграете.
    2) Можно использовать web worker. Web APi. Почитайте, может в вашем конкретном случае поможет.
    3) Можно заменить название свойств объектов на имена объектов, это можно осуществить на сервере, попросить back чуть менять структуру объекта.

    P.S. У вас в примере не массив, а объект.
    Ответ написан
    2 комментария
  • Middleware is not a function, почему такая ошибка?

    RomReed
    @RomReed
    JavaScript, Flutter, ReactNative, Redux, Firebase
    import thunk from "redux-thunk";
    Ответ написан
    Комментировать
  • Возможность выбрать карту для использования или альтернатива Leaflet?

    dom1n1k
    @dom1n1k
    По-нормальному это сделать невозможно по юридическим причинам - и Гугл, и Яндекс запрещают лицензионным соглашением использовать свои данные где-либо вне собственных АПИ.
    Существую плагины к Leaflet, которые "решают" эту проблему, но там адский костыль. Из лифлета загружается апи того же яндекса, и карта показывается внутри карты, как матрешка. Всё это очень неудобно, костыльно, глючно, несовместимо со сторонними плагинами...
    Ну то есть для простых случаев, когда нужно просто показать карту и чтобы она двигалась - ещё сгодится. Но если у вас "много динамических данных, разные маршруты, кластеризации и много всего" - забудьте. Придётся выбрать какой-то один движок и его придерживаться.
    Ответ написан
    9 комментариев