Skip to content
  • Home
  • Aktuell
  • Tags
  • 0 Ungelesen 0
  • Kategorien
  • Unreplied
  • Beliebt
  • GitHub
  • Docu
  • Hilfe
Skins
  • Light
  • Brite
  • Cerulean
  • Cosmo
  • Flatly
  • Journal
  • Litera
  • Lumen
  • Lux
  • Materia
  • Minty
  • Morph
  • Pulse
  • Sandstone
  • Simplex
  • Sketchy
  • Spacelab
  • United
  • Yeti
  • Zephyr
  • Dark
  • Cyborg
  • Darkly
  • Quartz
  • Slate
  • Solar
  • Superhero
  • Vapor

  • Standard: (Kein Skin)
  • Kein Skin
Einklappen
ioBroker Logo

Community Forum

  1. ioBroker Community Home
  2. Русский
  3. ioBroker
  4. Скрипты
  5. ioBroker скрипты
  6. Вопросы по написанию скриптов

NEWS

  • UPDATE 31.10.: Amazon Alexa - ioBroker Skill läuft aus ?
    apollon77A
    apollon77
    48
    3
    8.4k

  • Monatsrückblick – September 2025
    BluefoxB
    Bluefox
    13
    1
    2.0k

  • Neues Video "KI im Smart Home" - ioBroker plus n8n
    BluefoxB
    Bluefox
    15
    1
    2.5k

Вопросы по написанию скриптов

Geplant Angeheftet Gesperrt Verschoben ioBroker скрипты
358 Beiträge 29 Kommentatoren 108.7k Aufrufe
  • Älteste zuerst
  • Neuste zuerst
  • Meiste Stimmen
Antworten
  • In einem neuen Thema antworten
Anmelden zum Antworten
Dieses Thema wurde gelöscht. Nur Nutzer mit entsprechenden Rechten können es sehen.
  • B Offline
    B Offline
    Bosya
    schrieb am zuletzt editiert von
    #83

    @electric69:

    Вроде внутри самого обработчика on можно проверять - откуда пришло измерение - драйвера или vis/скрипта…

    Bosya, посмотри документацию на гитхабе… `
    На гитхабе я нашел только:

    from string New value is from defined adapter

    fromNe string New value is not from defined adapter

    oldFrom string Old value is from defined adapter

    oldFromNe string Old value is not from defined adapter

    Ключевое слово adapter. Может быть можно в качестве адаптера указать javascript.0? Не уверен, что это то что нужно.

    1 Antwort Letzte Antwort
    0
    • I Offline
      I Offline
      instalator
      schrieb am zuletzt editiert von
      #84

      @Bosya:

      Есть реально работающий пример с подпиской на изменения скриптов? `

      Собственно много таких скриптов у меня, вот например подписка на любые изменения

      on({id: 'javascript.0.vkontakte.search_track', change: 'any'}, function (obj) {
          if(obj.newState.val !== ''){
      
          }else{log('Не задана команда.');}
      });
      

      в javascript.0.vkontakte.search_track передаю другим скриптом

      if ((voiceArr[0] == 'найди' || voiceArr[0] == 'найти' || voiceArr[0] == 'включи') && (voiceArr[1] == 'песню' || voiceArr[1] == 'песня')){
             var track = '';
            for(var t = 0; t < voiceArr.length; t++) {
                if (voiceArr[t+2] == 'undefined'){voiceArr[2+t]='';}
                track += ' '+voiceArr[t+2];
            }
            track = track.replace(/\undefined/g, "");
              setState('javascript.0.vkontakte.search_track', track);
              log('Ищем трек'+track);
         }
      

      Все работает, не знаю в чем у тебя сложности

      Высокий уровень Децибел вреден для здоровья!

      http://blog.instalator.ru/

      1 Antwort Letzte Antwort
      0
      • R Offline
        R Offline
        RDim
        schrieb am zuletzt editiert von
        #85

        @Bosya:

        @electric69:

        @Bosya:

        Я так понимаю, что подписаться на состояние созданное в этом или другом скрипте нельзя?

        Не нашел прямого ответа здесь, но понимаю что ответ такой как и в CCU.IO:

        http://forum.iobroker.net/viewtopic.php … 0%B2.#p733 `
        Эээ, а можно расшифровать?))

        Какое состояние вы создали? По вашей ссылке вопрос был про свойство переменной - подтверждение изменения от драйвера или других сервисов… `

        Имеется в виду createState/setState ("переменная"). А в другом скртпте on("переменная"). У таких состояний Подтв. false, а у переменных сохданых драйверами true. Дальше объяснение по ссылке. Драйвера подписываются только на события с false, а скрипты с true? Есть возможность в скрипте подписаться на событие созданное и измененное в скрипте? `

        Немного по разному подписываемся:

        <u><size size="150">На порт меги</size></u>

        var statePortIn = $('megad.0.p5_Port');

        stateLineIn.on (function (obj)

        {

        Log('Порт сработал');

        }

        );

        <u><size size="150">На переменную</size></u>

        createState ('ButtonVar', false);

        var stateButtonVar=$('ButtonVar');

        on('javascript.0.ButtonVar', function (obj)

        {

        Log('Переменная изменена');

        }

        );

        1 Antwort Letzte Antwort
        0
        • B Offline
          B Offline
          Bosya
          schrieb am zuletzt editiert von
          #86

          @instalator:

          Собственно много таких скриптов у меня, вот например подписка на любые изменения

          on({id: 'javascript.0.vkontakte.search_track', change: 'any'}, function (obj) {
              if(obj.newState.val !== ''){
          
                  
              }else{log('Не задана команда.');}
          });
          

          в javascript.0.vkontakte.search_track передаю другим скриптом

          if ((voiceArr[0] == 'найди' || voiceArr[0] == 'найти' || voiceArr[0] == 'включи') && (voiceArr[1] == 'песню' || voiceArr[1] == 'песня')){
                 var track = '';
                for(var t = 0; t < voiceArr.length; t++) {
                    if (voiceArr[t+2] == 'undefined'){voiceArr[2+t]='';}
                    track += ' '+voiceArr[t+2];
                }
                track = track.replace(/\undefined/g, "");
                  setState('javascript.0.vkontakte.search_track', track);
                  log('Ищем трек'+track);
             }
          

          Все работает, не знаю в чем у тебя сложности `

          Спасибо, все заработало. Ошибка была в другом, а я перепробовал разные варианты и javascript.0 и без не работает. После примеров начал копать глубже - ошибку нашел…

          1 Antwort Letzte Antwort
          0
          • E Offline
            E Offline
            electric69
            schrieb am zuletzt editiert von
            #87

            Ребят, никто не задавался вопросом работать с ioBroker и Arduino+W5100 по http? Через адаптер simple-api.

            Надо сделать двухсторонний обмен данными между ардуинкой и iobroker, но не применяя MQTT.

            1 Antwort Letzte Antwort
            0
            • I Offline
              I Offline
              instalator
              schrieb am zuletzt editiert von
              #88

              @electric69:

              Ребят, никто не задавался вопросом работать с ioBroker и Arduino+W5100 по http? Через адаптер simple-api.

              Надо сделать двухсторонний обмен данными между ардуинкой и iobroker, но не применяя MQTT. `
              А почему без Mqtt?

              Высокий уровень Децибел вреден для здоровья!

              http://blog.instalator.ru/

              1 Antwort Letzte Antwort
              0
              • BluefoxB Offline
                BluefoxB Offline
                Bluefox
                schrieb am zuletzt editiert von
                #89

                @electric69:

                Ребят, никто не задавался вопросом работать с ioBroker и Arduino+W5100 по http? Через адаптер simple-api.

                Надо сделать двухсторонний обмен данными между ардуинкой и iobroker, но не применяя MQTT. `
                simple api использовать не обязательно. С помощью node-red можно построить какой угодно RESTful инерфейс.

                Так что всё упирается в вызов http get на ардуино.

                Вот с приёмом команд я не знаю. Не использую ардуино. Но должно быть не сложно:

                https://github.com/jjg/RESTduino

                1 Antwort Letzte Antwort
                0
                • E Offline
                  E Offline
                  electric69
                  schrieb am zuletzt editiert von
                  #90

                  Ребят, подскажите где поискать.

                  В адаптере javascript создаю переменную, к примеру MyVar. Значения принимает текстовые - on/off.

                  Как на нее подписаться правильно чтобы срабатывала подписка только если изменения пришли из адаптера vis.

                  Если изменения из самого джаваскрипт, или какого либо MQTT, simple-api, то функция подписки игнорировала бы изменение.

                  1 Antwort Letzte Antwort
                  0
                  • I Offline
                    I Offline
                    instalator
                    schrieb am zuletzt editiert von
                    #91

                    @electric69:

                    Ребят, подскажите где поискать.

                    В адаптере javascript создаю переменную, к примеру MyVar. Значения принимает текстовые - on/off.

                    Как на нее подписаться правильно чтобы срабатывала подписка только если изменения пришли из адаптера vis.

                    Если изменения из самого джаваскрипт, или какого либо MQTT, simple-api, то функция подписки игнорировала бы изменение. `
                    Сам не проверял но думаю тпримерно так

                    on({id: 'javascript.0.MyVar', change: 'any'}, function (obj) {
                        if(obj.newState.from == 	'web.0' && obj.newState.val == 'off'){
                            setState('javascript.0.MyVar', 'OK', true/*ack*/);
                        }
                    });
                    

                    Высокий уровень Децибел вреден для здоровья!

                    http://blog.instalator.ru/

                    1 Antwort Letzte Antwort
                    0
                    • BluefoxB Offline
                      BluefoxB Offline
                      Bluefox
                      schrieb am zuletzt editiert von
                      #92

                      @instalator:

                      @electric69:

                      Ребят, подскажите где поискать.

                      В адаптере javascript создаю переменную, к примеру MyVar. Значения принимает текстовые - on/off.

                      Как на нее подписаться правильно чтобы срабатывала подписка только если изменения пришли из адаптера vis.

                      Если изменения из самого джаваскрипт, или какого либо MQTT, simple-api, то функция подписки игнорировала бы изменение. `
                      Сам не проверял но думаю тпримерно так

                      on({id: 'javascript.0.MyVar', change: 'any'}, function (obj) {
                          if(obj.newState.from == 	'web.0' && obj.newState.val == 'off'){
                              setState('javascript.0.MyVar', 'OK', true/*ack*/);
                          }
                      });
                      ```` `  
                      

                      Или так

                      on({id: 'javascript.0.MyVar', change: 'any'}, function (obj) {
                          if((obj.newState.from == 'web.0' || obj.newState.from == 'system.adapter.web.0' ) && obj.newState.val == 'off'){
                              setState('javascript.0.MyVar', 'OK', true/*ack*/);
                          }
                      });
                      
                      1 Antwort Letzte Antwort
                      0
                      • I Offline
                        I Offline
                        instalator
                        schrieb am zuletzt editiert von
                        #93

                        BlueFox пытаюсь спарсить эту страницу, но насколько я понял в js не попадает динамически созданных элементов страницы, вариантов других нет?

                        ! https://maps.yandex.ru/197/barnaul/?ll= … to&rtm=atm

                        Высокий уровень Децибел вреден для здоровья!

                        http://blog.instalator.ru/

                        1 Antwort Letzte Antwort
                        0
                        • BluefoxB Offline
                          BluefoxB Offline
                          Bluefox
                          schrieb am zuletzt editiert von
                          #94

                          @instalator:

                          BlueFox пытаюсь спарсить эту страницу, но насколько я понял в js не попадает динамически созданных элементов страницы, вариантов других нет?

                          ! https://maps.yandex.ru/197/barnaul/?ll= … to&rtm=atm `
                          А что ты пытаешься "выпарсть"? Нужно брать оттуда же откуда страница данные берёт.

                          1 Antwort Letzte Antwort
                          0
                          • I Offline
                            I Offline
                            instalator
                            schrieb am zuletzt editiert von
                            #95

                            @Bluefox:

                            @instalator:

                            BlueFox пытаюсь спарсить эту страницу, но насколько я понял в js не попадает динамически созданных элементов страницы, вариантов других нет?

                            ! https://maps.yandex.ru/197/barnaul/?ll= … to&rtm=atm А что ты пытаешься "выпарсть"? Нужно брать оттуда же откуда страница данные берёт.
                            Спасибо! разобрался

                            Высокий уровень Децибел вреден для здоровья!

                            http://blog.instalator.ru/

                            1 Antwort Letzte Antwort
                            0
                            • I Offline
                              I Offline
                              instalator
                              schrieb am zuletzt editiert von
                              #96

                              @instalator:

                              @Bluefox:

                              @instalator:

                              BlueFox пытаюсь спарсить эту страницу, но насколько я понял в js не попадает динамически созданных элементов страницы, вариантов других нет?

                              ! https://maps.yandex.ru/197/barnaul/?ll= … to&rtm=atm А что ты пытаешься "выпарсть"? Нужно брать оттуда же откуда страница данные берёт.
                              Спасибо! разобрался `

                              Разобрался откуда страница берет) но как получить токен не пойму. http://forum.iobroker.net/viewtopic.php … 453#p16453

                              Высокий уровень Децибел вреден для здоровья!

                              http://blog.instalator.ru/

                              1 Antwort Letzte Antwort
                              0
                              • I Offline
                                I Offline
                                instalator
                                schrieb am zuletzt editiert von
                                #97

                                Как проверить JSON ответ от сервера на валидность? и вообще JSON ли отдан сервером?

                                if (JSON.parse(body)) так не работает, падает драйвер.

                                ! host-Server-PC 2015-12-23 22:30:53 error instance system.adapter.javascript.0 terminated with code 6 (uncaught exception)
                                ! SyntaxError: 2015-12-23 22:30:53 error at process._tickCallback (node.js:442:13)
                                ! SyntaxError: 2015-12-23 22:30:53 error at _stream_readable.js:944:16
                                ! SyntaxError: 2015-12-23 22:30:53 error at IncomingMessage.emit (events.js:117:20)
                                ! SyntaxError: 2015-12-23 22:30:53 error at IncomingMessage. (C:\ioBroker\node_modules\iobroker.javascript\node_modules\request\request.js:962:12)
                                ! SyntaxError: 2015-12-23 22:30:53 error at Request.emit (events.js:117:20)
                                ! SyntaxError: 2015-12-23 22:30:53 error at Request. (C:\ioBroker\node_modules\iobroker.javascript\node_modules\request\request.js:1035:10)
                                ! SyntaxError: 2015-12-23 22:30:53 error at Request.emit (events.js:98:17)
                                ! SyntaxError: 2015-12-23 22:30:53 error at Request.self.callback (C:\ioBroker\node_modules\iobroker.javascript\node_modules\request\request.js:198:22)
                                ! SyntaxError: 2015-12-23 22:30:53 error at Request._callback (script.js.Пробки:104:37)
                                ! SyntaxError: 2015-12-23 22:30:53 error at Object.parse (native)
                                ! SyntaxError: 2015-12-23 22:30:53 error Unexpected token (
                                ! uncaught 2015-12-23 22:30:53 error exception: Unexpected token (
                                Предварительно выполнив JSON.stringify(body)

                                ошибок меньше, но драйвер javascript все равно перезагружается:

                                ! error host.Server-PC instance system.adapter.javascript.0 terminated with code 6 (uncaught exception)

                                Высокий уровень Децибел вреден для здоровья!

                                http://blog.instalator.ru/

                                1 Antwort Letzte Antwort
                                0
                                • BluefoxB Offline
                                  BluefoxB Offline
                                  Bluefox
                                  schrieb am zuletzt editiert von
                                  #98

                                  @instalator:

                                  Как проверить JSON ответ от сервера на валидность? и вообще JSON ли отдан сервером?

                                  if (JSON.parse(body)) так не работает, падает драйвер.

                                  ! host-Server-PC 2015-12-23 22:30:53 error instance system.adapter.javascript.0 terminated with code 6 (uncaught exception)
                                  ! SyntaxError: 2015-12-23 22:30:53 error at process._tickCallback (node.js:442:13)
                                  ! SyntaxError: 2015-12-23 22:30:53 error at _stream_readable.js:944:16
                                  ! SyntaxError: 2015-12-23 22:30:53 error at IncomingMessage.emit (events.js:117:20)
                                  ! SyntaxError: 2015-12-23 22:30:53 error at IncomingMessage. (C:\ioBroker\node_modules\iobroker.javascript\node_modules\request\request.js:962:12)
                                  ! SyntaxError: 2015-12-23 22:30:53 error at Request.emit (events.js:117:20)
                                  ! SyntaxError: 2015-12-23 22:30:53 error at Request. (C:\ioBroker\node_modules\iobroker.javascript\node_modules\request\request.js:1035:10)
                                  ! SyntaxError: 2015-12-23 22:30:53 error at Request.emit (events.js:98:17)
                                  ! SyntaxError: 2015-12-23 22:30:53 error at Request.self.callback (C:\ioBroker\node_modules\iobroker.javascript\node_modules\request\request.js:198:22)
                                  ! SyntaxError: 2015-12-23 22:30:53 error at Request._callback (script.js.Пробки:104:37)
                                  ! SyntaxError: 2015-12-23 22:30:53 error at Object.parse (native)
                                  ! SyntaxError: 2015-12-23 22:30:53 error Unexpected token (
                                  ! uncaught 2015-12-23 22:30:53 error exception: Unexpected token (
                                  Предварительно выполнив JSON.stringify(body)

                                  ошибок меньше, но драйвер javascript все равно перезагружается:

                                  ! error host.Server-PC instance system.adapter.javascript.0 terminated with code 6 (uncaught exception) `

                                      var result;
                                      try {
                                          result = JSON.parse(body)
                                      } catch (err) {
                                          console.log("Не парсится!");
                                          result = null;
                                      }
                                  
                                  
                                  1 Antwort Letzte Antwort
                                  0
                                  • S Offline
                                    S Offline
                                    spectrekr
                                    schrieb am zuletzt editiert von
                                    #99

                                    В скрипте подключаю модуль и создаю переменную:

                                    var mysql = require('mysql');
                                    
                                    var connection = mysql.createConnection({
                                        host:     'localhost',
                                        user:     'login',
                                        password: 'pass',
                                        database: 'bd',
                                        socketPath: '/var/run/mysqld/mysqld.sock'
                                    });
                                    
                                    

                                    Потом подписываюсь на некую переменную.

                                    on({id: 'javascript.0.sms.id', change: 'any'}, function (obj) {
                                    	count = obj.newState.val - obj.oldState.val;
                                    	log("чего-то");
                                    }
                                    
                                    

                                    Как передать переменную connection в подписку?

                                    1 Antwort Letzte Antwort
                                    0
                                    • BluefoxB Offline
                                      BluefoxB Offline
                                      Bluefox
                                      schrieb am zuletzt editiert von
                                      #100

                                      @spectrekr:

                                      В скрипте подключаю модуль и создаю переменную:

                                      var mysql = require('mysql');
                                      
                                      var connection = mysql.createConnection({
                                          host:     'localhost',
                                          user:     'login',
                                          password: 'pass',
                                          database: 'bd',
                                          socketPath: '/var/run/mysqld/mysqld.sock'
                                      });
                                      
                                      

                                      Потом подписываюсь на некую переменную.

                                      on({id: 'javascript.0.sms.id', change: 'any'}, function (obj) {
                                      	count = obj.newState.val - obj.oldState.val;
                                      	log("чего-то");
                                      }
                                      
                                      

                                      Как передать переменную connection в подписку? `
                                      Обе части кода просто должны быть в одном скрипте. Тогда connection видна везде:

                                      var mysql = require('mysql');
                                      
                                      var connection = mysql.createConnection({
                                          host:     'localhost',
                                          user:     'login',
                                          password: 'pass',
                                          database: 'bd',
                                          socketPath: '/var/run/mysqld/mysqld.sock'
                                      });
                                      
                                      on({id: 'javascript.0.sms.id', change: 'any'}, function (obj) {
                                      	count = obj.newState.val - obj.oldState.val;
                                      	log("чего-то");
                                      	connection.query('INSERT table...');
                                      });
                                      
                                      1 Antwort Letzte Antwort
                                      0
                                      • S Offline
                                        S Offline
                                        spectrekr
                                        schrieb am zuletzt editiert von
                                        #101

                                        Так и написано

                                        ! connection.query('SELECT max(id) AS id FROM inbox', function(err, res_id, fields) { if (err) throw err; setState('sms.id', res_id[0].id); log(getState('sms.id').val); }); ! on({id: 'javascript.0.sms.id', change: 'any'}, function (obj) { if (obj.oldState.val < obj.newState.val){ count = obj.newState.val - obj.oldState.val; } log(count); if (count > 1){ connection.query('SELECT UDH FROM inbox WHERE ID = ?', [getState('sms.id').val], function(err, res_udh, fields) { if (err) throw err; log(res_udh[0].UDH); if(res_udh[0].UDH !== ''){ setState('sms.udh', res_udh[0].UDH.substring(0, res[0].UDH.length - 1)); log(getState('sms.udh').val); } }); } }); !
                                        Первый запрос выполняется и внем все прекрасно получает, потом производит подписку и внутри уже выдает ошибку.

                                        ! Error: Cannot enqueue Query after invoking quit. at Protocol._validateEnqueue (/opt/iobroker/node_modules/iobroker.javascript/node_modules/mysql/lib/protocol/Protocol.js:202:16) at Protocol._enqueue (/opt/iobroker/node_modules/iobroker.javascript/node_modules/mysql/lib/protocol/Protocol.js:135:13) at Connection.query (/opt/iobroker/node_modules/iobroker.javascript/node_modules/mysql/lib/Connection.js:201:25) at Object. (script.js.SMS:41:20) at Object.subs.callback (/opt/iobroker/node_modules/iobroker.javascript/javascript.js:1206:48) at /opt/iobroker/node_modules/iobroker.javascript/javascript.js:541:48 at getObjectEnums (/opt/iobroker/node_modules/iobroker.javascript/javascript.js:2430:17) at checkPatterns (/opt/iobroker/node_modules/iobroker.javascript/javascript.js:537:17) at Object.utils.adapter.stateChange (/opt/iobroker/node_modules/iobroker.javascript/javascript.js:215:17) at Object.that.states.States.change (/opt/iobroker/node_modules/iobroker.js-controller/lib/adapter.js:1969:80) at Socket.StatesInMemClient.client.on.connectionTimeout (/opt/iobroker/node_modules/iobroker.js-controller/lib/states/statesInMemClient.js:45:30) at Socket.Emitter.emit (/opt/iobroker/node_modules/iobroker.js-controller/node_modules/socket.io-client/node_modules/component-emitter/index.js:131:20) at Socket.onevent (/opt/iobroker/node_modules/iobroker.js-controller/node_modules/socket.io-client/lib/socket.js:263:10) at Socket.onpacket (/opt/iobroker/node_modules/iobroker.js-controller/node_modules/socket.io-client/lib/socket.js:221:12) at Manager. (/opt/iobroker/node_modules/iobroker.js-controller/node_modules/socket.io-client/node_modules/component-bind/index.js:21:15) at Manager.Emitter.emit (/opt/iobroker/node_modules/iobroker.js-controller/node_modules/socket.io-client/node_modules/component-emitter/index.js:131:20) at Manager.ondecoded (/opt/iobroker/node_modules/iobroker.js-controller/node_modules/socket.io-client/lib/manager.js:333:8) at Decoder. (/opt/iobroker/node_modules/iobroker.js-controller/node_modules/socket.io-client/node_modules/component-bind/index.js:21:15) at Decoder.Emitter.emit (/opt/iobroker/node_modules/iobroker.js-controller/node_modules/socket.io-client/node_modules/socket.io-parser/node_modules/component-emitter/index.js:134:20) at Decoder.add (/opt/iobroker/node_modules/iobroker.js-controller/node_modules/socket.io-client/node_modules/socket.io-parser/index.js:247:12) at Manager.ondata (/opt/iobroker/node_modules/iobroker.js-controller/node_modules/socket.io-client/lib/manager.js:323:16) at Socket. (/opt/iobroker/node_modules/iobroker.js-controller/node_modules/socket.io-client/node_modules/component-bind/index.js:21:15) at Socket.Emitter.emit (/opt/iobroker/node_modules/iobroker.js-controller/node_modules/socket.io-client/node_modules/engine.io-client/node_modules/component-emitter/index.js:134:20) at Socket.onPacket (/opt/iobroker/node_modules/iobroker.js-controller/node_modules/socket.io-client/node_modules/engine.io-client/lib/socket.js:441:14) at WS. (/opt/iobroker/node_modules/iobroker.js-controller/node_modules/socket.io-client/node_modules/engine.io-client/lib/socket.js:258:10) at WS.Emitter.emit (/opt/iobroker/node_modules/iobroker.js-controller/node_modules/socket.io-client/node_modules/engine.io-client/node_modules/component-emitter/index.js:134:20) at WS.Transport.onPacket (/opt/iobroker/node_modules/iobroker.js-controller/node_modules/socket.io-client/node_modules/engine.io-client/lib/transport.js:143:8) at WS.Transport.onData (/opt/iobroker/node_modules/iobroker.js-controller/node_modules/socket.io-client/node_modules/engine.io-client/lib/transport.js:135:8) at WebSocket.ws.onmessage (/opt/iobroker/node_modules/iobroker.js-controller/node_modules/socket.io-client/node_modules/engine.io-client/lib/transports/websocket.js:132:10) at WebSocket.onMessage (/opt/iobroker/node_modules/iobroker.js-controller/node_modules/socket.io-client/node_modules/engine.io-client/node_modules/ws/lib/WebSocket.js:418:14) at WebSocket.emit (events.js:98:17) at Receiver.ontext (/opt/iobroker/node_modules/iobroker.js-controller/node_modules/socket.io-client/node_modules/engine.io-client/node_modules/ws/lib/WebSocket.js:816:10) at /opt/iobroker/node_modules/iobroker.js-controller/node_modules/socket.io-client/node_modules/engine.io-client/node_modules/ws/lib/Receiver.js:477:18 at Receiver.applyExtensions (/opt/iobroker/node_modules/iobroker.js-controller/node_modules/socket.io-client/node_modules/engine.io-client/node_modules/ws/lib/Receiver.js:364:5) at /opt/iobroker/node_modules/iobroker.js-controller/node_modules/socket.io-client/node_modules/engine.io-client/node_modules/ws/lib/Receiver.js:466:14 at Receiver.flush (/opt/iobroker/node_modules/iobroker.js-controller/node_modules/socket.io-client/node_modules/engine.io-client/node_modules/ws/lib/Receiver.js:340:3) at Receiver.opcodes.1.finish (/opt/iobroker/node_modules/iobroker.js-controller/node_modules/socket.io-client/node_modules/engine.io-client/node_modules/ws/lib/Receiver.js:482:12) at Receiver. (/opt/iobroker/node_modules/iobroker.js-controller/node_modules/socket.io-client/node_modules/engine.io-client/node_modules/ws/lib/Receiver.js:457:31) at Receiver.add (/opt/iobroker/node_modules/iobroker.js-controller/node_modules/socket.io-client/node_modules/engine.io-client/node_modules/ws/lib/Receiver.js:95:24) at Socket.realHandler (/opt/iobroker/node_modules/iobroker.js-controller/node_modules/socket.io-client/node_modules/engine.io-client/node_modules/ws/lib/WebSocket.js:800:20) at Socket.emit (events.js:95:17) at Socket. (stream_readable.js:765:14) at Socket.emit (events.js:92:17) at emitReadable (_stream_readable.js:427:10) at emitReadable (_stream_readable.js:423:5) at readableAddChunk (_stream_readable.js:166:9) at Socket.Readable.push (_stream_readable.js:128:10) at TCP.onread (net.js:529:21)
                                        На драйвер пока знаний не хватает, пытаюсь написать скрипт, а потом уже буду пытаться преобразовать все в драйвер.

                                        UPD: Разобрался, он закрывал соединение не зависимо от подписки.

                                        1 Antwort Letzte Antwort
                                        0
                                        • I Offline
                                          I Offline
                                          instalator
                                          schrieb am zuletzt editiert von
                                          #102

                                          есть переменная

                                          var menu = [
                                              [
                                                  ['Заказываем как обычно?', 'да', 'нет', [0,0,2]],
                                                  ['На какой день?', 'сегодня', 'завтра'],
                                                  ['На какое время?', 'утро', 'обед', 'вечер'],
                                                  ['Я делаю заказ'],
                                          
                                              ],
                                              [
                                                  ['На какой день?', 'сегодня', 'завтра'],
                                                  ['На какое время?', 'утро', 'обед', 'вечер'],
                                                  ['Какое количество?'],
                                              ]
                                          ];
                                          
                                          

                                          Пытаюсь узнать длину массива menu[0][0]

                                          log('menu[0][0].length' + menu[0][0].length);
                                          

                                          Выдает 14, целый час бился. Перезапускал даже IoB.

                                          Но после того как узнал длину следующего элемента, все встало на свои места

                                          ! ````
                                          23:25:39.178 [info] javascript.0 Start javascript script.js.МЕНЮ
                                          23:25:39.185 [info] javascript.0 script.js.МЕНЮ: menu[0][0].length-14
                                          23:25:39.185 [info] javascript.0 script.js.МЕНЮ: registered 1 subscription and 0 schedules
                                          23:25:58.064 [info] javascript.0 Stop script script.js.МЕНЮ
                                          23:25:58.243 [info] javascript.0 Start javascript script.js.МЕНЮ
                                          23:25:58.250 [info] javascript.0 script.js.МЕНЮ: menu[1][0].length3
                                          23:25:58.250 [info] javascript.0 script.js.МЕНЮ: registered 1 subscription and 0 schedules
                                          23:26:14.320 [info] javascript.0 Stop script script.js.МЕНЮ
                                          23:26:14.512 [info] javascript.0 Start javascript script.js.МЕНЮ
                                          23:26:14.525 [info] javascript.0 script.js.МЕНЮ: menu[0][1].length3
                                          23:26:14.525 [info] javascript.0 script.js.МЕНЮ: registered 1 subscription and 0 schedules
                                          23:26:24.575 [info] javascript.0 Stop script script.js.МЕНЮ
                                          23:26:24.828 [info] javascript.0 Start javascript script.js.МЕНЮ
                                          23:26:24.835 [info] javascript.0 script.js.МЕНЮ: menu[0][0].length4
                                          23:26:24.835 [info] javascript.0 script.js.МЕНЮ: registered 1 subscription and 0 schedules

                                          Это из-за чего такие глюки происходят в js?
                                          
                                          Добавлено.
                                          
                                          В скрипте так и продолжает выдавать 14.
                                          
                                          есть еще массив с одним элементом выдает длину 23:34:38.188 [info] javascript.0 script.js.МЕНЮ: result.length-11

                                          Высокий уровень Децибел вреден для здоровья!

                                          http://blog.instalator.ru/

                                          1 Antwort Letzte Antwort
                                          0
                                          Antworten
                                          • In einem neuen Thema antworten
                                          Anmelden zum Antworten
                                          • Älteste zuerst
                                          • Neuste zuerst
                                          • Meiste Stimmen


                                          Support us

                                          ioBroker
                                          Community Adapters
                                          Donate

                                          717

                                          Online

                                          32.4k

                                          Benutzer

                                          81.4k

                                          Themen

                                          1.3m

                                          Beiträge
                                          Community
                                          Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen | Einwilligungseinstellungen
                                          ioBroker Community 2014-2025
                                          logo
                                          • Anmelden

                                          • Du hast noch kein Konto? Registrieren

                                          • Anmelden oder registrieren, um zu suchen
                                          • Erster Beitrag
                                            Letzter Beitrag
                                          0
                                          • Home
                                          • Aktuell
                                          • Tags
                                          • Ungelesen 0
                                          • Kategorien
                                          • Unreplied
                                          • Beliebt
                                          • GitHub
                                          • Docu
                                          • Hilfe