Nano Hash - криптовалюты, майнинг, программирование

Нативная сборка приложения Sencha перезаписывает наш пользовательский код

Мы уже довольно давно работаем над этим приложением, разработанным с помощью Sencha Touch 2.

Обычно мы тестируем и отлаживаем код с помощью Chrome и Ripple.

Проблема, с которой мы столкнулись, заключается в том, что мы добавили некоторую пользовательскую логику поиска и группировки в одно из наших представлений списков. При тестировании и отладке с помощью Chrome все работало, как и ожидалось, но затем мы использовали команду для его упаковки, чтобы интегрировать его с Cordova и создать приложения для Android и iOS. Мы использовали следующую команду:

sencha app build native

По какой-то причине код, созданный с помощью этой команды, перезаписывает наш код пользовательского поиска и группировки JavaScript.

Почему это могло происходить. Нам нравится думать, что это не инструмент сенча работает неправильно, а то, что мы делаем неправильно, что вызывает это.

Мы не знаем, в чем может быть причина. Кто-нибудь может пролить свет на это? Почему наши пользовательские функции группировки и фильтрации перезаписываются при упаковке приложения?

Ниже приведен отрывок о том, как мы определяем метод группировки в нашем магазине. Опять же, когда мы пробуем это в нашей среде отладки, все работает правильно. Проблема в том, что когда мы упаковываем его с помощью приведенной выше команды, функция группировки заменяется функцией группировки sencha touch 2 по умолчанию, которая возвращает первый символ строки.

Ext.define('app.store.definitions',{
    extend:'Ext.data.Store',
    requires: [
        'Ext.data.Connection'
    ],

    config:{
        fields: ['id','name', 'Description'],
        sorters: 'name',
        grouper: function(record) {
           // these are the translation arrays
           var accents = "ÃÀÁÄÂÈÉËÊÌÍÏÎÒÓÖÔÙÚÜÛ";
           var desiredvalue = "AAAAAEEEEIIIIOOOOUUUU";

           // first we upercase the first character of the name
           var firstchar = record.get('name').toUpperCase()[0];

           //next we check if it is a special character by checking position in accents string
           var n = accents.indexOf(firstchar);

          // if character is in accents (means it is a special character) we get corresponding normal character
          if (n <> -1)
             { firstchar = desiredvalue.charAt(n);
             };

          // and now we just return this value ad the grouping value 
          return firstchar;
      }

После выполнения «нативной сборки приложения sencha» и распаковки сгенерированного кода мы понимаем, что функция группировки была заменена на

       grouper: function(record) {
          var firstchar = record.get('name`);
          return firstchar;
      }

  • Вы изменяли исходные файлы Touch напрямую или расширяли компонент списка? 22.04.2014
  • Мы расширяем список, но большая часть перезаписываемого кода находится в определении хранилища или в контроллере. В качестве примера я добавил код нашей функции группировки в исходный вопрос. 22.04.2014
  • Я не понимаю, в чем может быть причина того, что при сборке нативного приложения наш код подменяется на эти функции. 24.04.2014

Ответы:


1

Я протестировал нативную сборку одного из своих приложений с группировщиком, и она не заменяет мой код. Я думаю, вам нужно указать параметр groupFn внутри литерала объекта grouper. См. следующий пример:

Ext.define('app.store.definitions',{
    extend:'Ext.data.Store',
    requires: [
        'Ext.data.Connection'
    ],

    config:{
        fields: ['id','name', 'Description'],
        sorters: 'name',
        grouper: {
            groupFn: function(record) {
                // these are the translation arrays
                var accents = "ÃÀÁÄÂÈÉËÊÌÍÏÎÒÓÖÔÙÚÜÛ";
                var desiredvalue = "AAAAAEEEEIIIIOOOOUUUU";

                // first we upercase the first character of the name
                var firstchar = record.get('name').toUpperCase()[0];

                //next we check if it is a special character by checking position in accents string
                var n = accents.indexOf(firstchar);

                // if character is in accents (means it is a special character) we get corresponding normal character
                if (n <> -1) { 
                    firstchar = desiredvalue.charAt(n);
                };

                // and now we just return this value ad the grouping value 
                return firstchar;
           }
       }
24.04.2014
  • Мы попытались определить groupFn, но по-прежнему получаем ту же проблему. 27.04.2014
  • что может быть причиной того, что приложение работает нормально при тестировании в браузере, но когда в полученном коде упаковано встроенное приложение sencha, функция группировки, описанная выше, была заменена на: grouper: function (a) {return a.get("name")[0]}, которая является функцией группировки по умолчанию? 28.04.2014
  • Новые материалы

    Кластеризация: более глубокий взгляд
    Кластеризация — это метод обучения без учителя, в котором мы пытаемся найти группы в наборе данных на основе некоторых известных или неизвестных свойств, которые могут существовать. Независимо от..

    Как написать эффективное резюме
    Предложения по дизайну и макету, чтобы представить себя профессионально Вам не позвонили на собеседование после того, как вы несколько раз подали заявку на работу своей мечты? У вас может..

    Частный метод Python: улучшение инкапсуляции и безопасности
    Введение Python — универсальный и мощный язык программирования, известный своей простотой и удобством использования. Одной из ключевых особенностей, отличающих Python от других языков, является..

    Как я автоматизирую тестирование с помощью Jest
    Шутка для победы, когда дело касается автоматизации тестирования Одной очень важной частью разработки программного обеспечения является автоматизация тестирования, поскольку она создает..

    Работа с векторными символическими архитектурами, часть 4 (искусственный интеллект)
    Hyperseed: неконтролируемое обучение с векторными символическими архитектурами (arXiv) Автор: Евгений Осипов , Сачин Кахавала , Диланта Хапутантри , Тимал Кемпития , Дасвин Де Сильва ,..

    Понимание расстояния Вассерштейна: мощная метрика в машинном обучении
    В обширной области машинного обучения часто возникает необходимость сравнивать и измерять различия между распределениями вероятностей. Традиционные метрики расстояния, такие как евклидово..

    Обеспечение масштабируемости LLM: облачный анализ с помощью AWS Fargate и Copilot
    В динамичной области искусственного интеллекта все большее распространение получают модели больших языков (LLM). Они жизненно важны для различных приложений, таких как интеллектуальные..