Хобрук: Ваш путь к мастерству в программировании

Как собрать Modernizr с беседкой и бранчем - отсутствует main в bower.json

Я прочитал эту ошибку github, в которой говорится:

нет основного файла, который должен быть в основном.

У меня modernizr 3.0.0 установлен автоматически как зависимость от Foundation 5.5.2, и я пытаюсь создать свой проект с помощью Brunch.

При запуске brunch build я получаю следующую ошибку:

Error: Component JSON file "/path/to/brunch-test/bower_components/modernizr/.bower.json" must havemainproperty. See https://github.com/paulmillr/read-components#README

Итак, следуя проблеме с чтением компонентов, я пытаюсь переопределить main Modernizr в моем корневом каталоге bower.json. но не уверен, как это сделать, поскольку нет простого скомпилированного modernizr.js.

Я знаю, что modernizr предназначен для индивидуальной настройки, и действительно новости выпуска modernizr 3 состояние есть a really cool solution of dynamically creating a custom package that can be installed via bower но я не могу найти информацию об этом?


Ответы:


1

Хорошо, я понял это.

Итак, мое дерево каталогов выглядит примерно так (упрощенно):

/
|-- bower.json
|-- bower_components
  |-- modernizr
    |-- bin
      |-- modernizr

Я вошел в bower_components/modernizr и запустил npm install, чтобы получить зависимости, необходимые для запуска bin/modernizr билдера.

Затем я зашел на их веб-сайт, чтобы выбрать нужные мне функции: https://modernizr.com/download?setclasses.

Затем я нажал Build и загрузил Command Line Config, который я поместил в корневой каталог моего проекта как modernizr-config.json.

Затем я запустил bin/modernizr -c ../../modernizr-config.json, поместив специально созданный modernizr.js в /bower_components/modernizr/modernizr.js.

Наконец, в моем корневом каталоге bower.json я добавил (после ошибки чтения компонентов):

"overrides": {
  "modernizr": {
    "main": "modernizr.js"
  }
}

и brunch build теперь прекрасно работает.

01.10.2015
  • Спасибо за информацию - я думал, что, судя по их заявлению, вы сможете использовать исключительно Bower, но необходимость заранее вручную собирать Modernizr добавляет нежелательную сложность. 02.10.2015
  • То же самое здесь, надеялся, что у них будет поддержка Bower на ходу, но увы. 18.01.2017
  • Новые материалы

    Dall-E 2: недавние исследования показывают недостатки в искусстве, созданном искусственным интеллектом
    DALL-E 2 — это всеобщее внимание в индустрии искусственного интеллекта. Люди в списке ожидания пытаются заполучить продукт. Что это означает для развития креативной индустрии? О применении ИИ в..

    «Очень простой» эволюционный подход к обучению с подкреплением
    В прошлом семестре я посетил лекцию по обучению с подкреплением (RL) в моем университете. Честно говоря, я присоединился к нему официально, но я редко ходил на лекции, потому что в целом я нахожу..

    Освоение информационного поиска: создание интеллектуальных поисковых систем (глава 1)
    Глава 1. Поиск по ключевым словам: основы информационного поиска Справочная глава: «Оценка моделей поиска информации: подробное руководство по показателям производительности » Глава 1: «Поиск..

    Фишинг — Упаковано и зашифровано
    Будучи старшим ИТ-специалистом в небольшой фирме, я могу делать много разных вещей. Одна из этих вещей: специалист по кибербезопасности. Мне нравится это делать, потому что в настоящее время я..

    ВЫ РЕГРЕСС ЭТО?
    Чтобы понять, когда использовать регрессионный анализ, мы должны сначала понять, что именно он делает. Вот простой ответ, который появляется, когда вы используете Google: Регрессионный..

    Не зря же это называют интеллектом
    Стек — C#, Oracle Опыт — 4 года Работа — Разведывательный корпус Мне пора служить Может быть, я немного приукрашиваю себя, но там, где я живу, есть обязательная военная служба на 3..

    LeetCode Проблема 41. Первый пропущенный положительный результат
    LeetCode Проблема 41. Первый пропущенный положительный результат Учитывая несортированный массив целых чисел, найдите наименьшее пропущенное положительное целое число. Пример 1: Input:..