Skip to content

JavaScript

2.5k Topics 49.4k Posts

Hilfe für Skripterstellung mit JavaScript

NEWS

  • [gelöst] delete und setObject führt zu keinem Ergebnis

    2
    0 Votes
    2 Posts
    166 Views
    Ben1983B
    @ben1983 Habe es heraus bekommen. Man muss hier den Wert zu null setzen, dann wird er gelöscht. const selectorLorawan = $(`state[id=lorawan.1.bbea74d6-1fc5-4238-af20-d2aecdbb4f8e.devices.70b3d52dd302759e.uplink.decoded.targetTemperatureFloat]`); const CustomInstanz = 'lorawan.1'; // Schedules beim Skriptstart erzeugen: selectorLorawan.each((id,i)=>{ deleteCommonCustom(id); }); function deleteCommonCustom(id) { const obj = getObject(id); obj.common.custom[CustomInstanz] = null; setObject(id,obj); }
  • Const richtig bei timestamp (toTimeString)

    18
    1
    0 Votes
    18 Posts
    1k Views
    T
    @oliverio ich glaube das Problem wird sein, das er die Tabelle nur erweitert. Um gestern, heute einzufügen, muss die Tabelle im Anschluß komplett überarbeitet werden. Sprich jedes Datum gegen das aktuelle geprüft werden.
  • Javascript für Zendure Hyper Steuerung

    5
    1
    0 Votes
    5 Posts
    492 Views
    L
    @intruder7 Du musst alles was mit const hyper2 = { name: 'Hyper2', inputLimitDP: 'zendure-solarflow.0.xxxxxx.yyyyyyyy.control.setInputLimit', inputDP: 'zendure-solarflow.0.xxxxxx.yyyyyyyy.gridInputPower', outputLimitDP: 'zendure-solarflow.0.xxxxxx.yyyyyyyy.control.setOutputLimit', outputDP: 'zendure-solarflow.0.xxxxxx.yyyyyyyy.outputHomePower', acModeDP: 'zendure-solarflow.0.xxxxxx.yyyyyyyy.control.acMode', pvLeistungDP: 'zendure-solarflow.0.xxxxxx.yyyyyyyy.solarInputPower', socDP: 'zendure-solarflow.0.xxxxxx.yyyyyyyy.electricLevel', }; zu tun hat rausschmeißen
  • Fritz!Box Daten auslesen, Gerätetraffic und Filter setzen

    Moved
    1
    0 Votes
    1 Posts
    237 Views
    No one has replied
  • Objekte dynamisch per typescript zu vis-View hinzufügen?

    1
    0 Votes
    1 Posts
    92 Views
    No one has replied
  • iobroker-typen einbinden für typescript

    14
    0 Votes
    14 Posts
    719 Views
    I
    @ticaki Ok, ich versuchs mal mit damit. Muss das erst mal durchschauen.
  • mqtt JSON in Datenpunkt schreiben

    6
    1
    0 Votes
    6 Posts
    374 Views
    F
    @paul53 Ich danke dir Paul ;-)
  • Script im VIS Reiter „Skript“ anlegen

    2
    0 Votes
    2 Posts
    222 Views
    M
    @exmatador Geht nur bis V1.6.0 [image: 1755550749577-1e93a2f2-1631-4d5a-81c1-cf0975cf86e7-image.png] <div id="threejs" style="width:600px; height: 400px"></div> Skripte-Reiter (function loadThree(url, onload){ var s = document.createElement('script'); s.src = url; s.onload = onload; s.onerror = e => console.error('THREE laden fehlgeschlagen:', e); document.head.appendChild(s); })( 'https://cdn.jsdelivr.net/npm/three@0.160.0/build/three.min.js', // UMD-Build function init(){ console.log('THREE geladen:', typeof THREE); // sollte "object" loggen setTimeout(function(){ const container = document.getElementById('threejs'); if (!container) { console.error('Container #threejs fehlt!'); return; } const w = container.clientWidth, h = container.clientHeight; const scene = new THREE.Scene(); const camera = new THREE.PerspectiveCamera(75, w/h, 0.1, 1000); const renderer = new THREE.WebGLRenderer({ antialias:true }); renderer.setSize(w, h); container.appendChild(renderer.domElement); const cube = new THREE.Mesh( new THREE.BoxGeometry(), new THREE.MeshBasicMaterial({ color: 0x00ff00 }) ); scene.add(cube); camera.position.z = 5; (function animate(){ requestAnimationFrame(animate); cube.rotation.x += 0.01; cube.rotation.y += 0.01; renderer.render(scene, camera); })(); },300) } ); [image: 1755550806700-800fc1f6-a07b-4e38-8f2d-33c6ad527942-image.png] Hinweis: In neueren Three-Versionen liefern CDNs oft nur ESM (three.module.js), was in VIS nicht läuft (Unexpected token export).
  • [gelöst] Selector hat nicht alle aktuellen States

    1
    0 Votes
    1 Posts
    140 Views
    No one has replied
  • Node.js Script in iobroker integrieren

    40
    0 Votes
    40 Posts
    8k Views
    L
    @oliverio OK ich habe mal mit Hilfe von ChatGPT die Codezeile abgeändert .then((text) => { const deviceDetails = text .trim() .split('\n') .reduce((obj, str) => { const [key, val] = str.split('='); if (key && typeof val !== 'undefined') { obj[key] = val.trim(); } return obj; }, {}); return deviceDetails; }); Jetzt läuft es. Vielen Dank
  • Wireguard Server abfragen -> Client Infos

    25
    0 Votes
    25 Posts
    2k Views
    NegaleinN
    @kuddel sagte in Wireguard Server abfragen -> Client Infos: Sollte ohne Anpassungen laufen. Danke Es läuft, mir wird in 0_userdata.0.wireguard-clients.Wireguard-JSON-History der Client gezeigt, der nach Scriptstart verbunden wurde. [image: 1753564121212-f6a3c312-e55b-4f6f-b9d4-4e15b7678df9-image.png] Aber 0_userdata.0.wireguard-clients.Wireguard-JSON bleibt leer. [image: 1753563870350-20930bb2-0aba-4331-8cf4-ce546cceba30-image-resized.png] Log vom Script 26.7.2025, 22:59:03.091 [info ]: javascript.1 (632) script.js.Netzwerk.Wireguard-Tabelle: Stopping script 26.7.2025, 22:59:03.098 [info ]: javascript.0 (606) script.js.Netzwerk.Wireguard-Tabelle: Stopping script 26.7.2025, 22:59:29.994 [info ]: javascript.0 (606) script.js.Netzwerk.Wireguard-Tabelle: start JavaScript (Javascript/js) 26.7.2025, 22:59:30.016 [info ]: javascript.0 (606) script.js.Netzwerk.Wireguard-Tabelle: registered 56 subscriptions, 0 schedules, 0 messages, 0 logs and 0 file subscriptions 26.7.2025, 23:01:24.263 [warn ]: javascript.0 (606) at Object.wireguard_history (script.js.Netzwerk.Wireguard-Tabelle:136:22) 26.7.2025, 23:01:24.263 [warn ]: javascript.0 (606) at Object.wireguard_history (script.js.Netzwerk.Wireguard-Tabelle:144:20) 26.7.2025, 23:01:24.264 [error]: javascript.0 (606) script.js.Netzwerk.Wireguard-Tabelle: Error: TypeError: Cannot read properties of null (reading 'split') 26.7.2025, 23:01:24.264 [error]: javascript.0 (606) script.js.Netzwerk.Wireguard-Tabelle: at Object.wireguard_history (script.js.Netzwerk.Wireguard-Tabelle:144:57)
  • Fehlermeldung beim Schreiben von Daten in influxdb2

    5
    0 Votes
    5 Posts
    397 Views
    S
    @homoran said in Fehlermeldung beim Schreiben von Daten in influxdb2: schreibst du direkt in die DB? warum nicht in einen DP, der vom Adapter geloggt wird? Ich habe das Programm grundsätzlich von @haus-automatisierung übernommen und mit den Bezeichnungen für meine Datenpunkte angepasst (hoffentlich richtig). Wenn ich es richtig verstanden habe, ist der Zweck, dass die Daten dann einen identischen Zeitstempel haben. Ich schau mal, wie ich den Tieout erhöhen kann. Ich würde gerne mal testen, was bei einem einzelnen Schreibbefehl passiert. Wie müsste das Script dafür in Blockly aussehen? Erhalte ich dann eine Antwort/Bestätigung von influxdb?
  • LUPUSEC Alarmanlage einbinden

    Moved javascript
    204
    0 Votes
    204 Posts
    57k Views
    Captain-pattyC
    @stuebi hast du noch eine Idee?
  • javascript-Adapter bindet console.log nicht ein bei require

    javascript
    13
    0 Votes
    13 Posts
    740 Views
    OliverIOO
    @axel21 Gut, workaround ist da, ich werde bei Gelegenheit selber mal experimentieren.
  • [gelöst] Problem: Abruf von Strompreisen mit JS und Axios

    16
    0 Votes
    16 Posts
    1k Views
    fuzzy1955F
    @johgre sagte in [gelöst] Problem: Abruf von Strompreisen mit JS und Axios: Das iteriert jetzt durch das ResponseArray und schreibt alle Werte mal raus. Danke nochmals! Das ResponseArray läuft super! Genau das brauchte ich
  • setStateAsync in externem js-file evtl mit require??

    javascript
    7
    0 Votes
    7 Posts
    465 Views
    OliverIOO
    @axel21 ja scopes ist schon ein Thema, was man erst nach einer weile versteht. Wer kennt schon den Unterschied zwischen var und let oder einer normalen Function oder einer Arrow Function ()-> Hier gute quellen zur Erklärung. https://javascript.info/variables https://javascript.info/closure sowie 2.15-2.17 + 6.6,6.7,6.10,6.11
  • Shelly Adapter: online DP in Script auswerten

    1
    1
    0 Votes
    1 Posts
    115 Views
    No one has replied
  • Skriptausführung ioBroker.javascript: CPU-Grundlast 40 %

    9
    0 Votes
    9 Posts
    615 Views
    OliverIOO
    @ceram Die Sync getState kannst du einfach umstellen durch await getStateAsync Das hat den selben Effekt. Ein echtes Sync gibtves bei JavaScript eh nie.
  • Javascript bringt Warnung

    5
    0 Votes
    5 Posts
    472 Views
    paul53P
    @fischerict sagte: kommt die Warnung nun nicht mehr Vermutlich hat der Neustart der hm-rega-Instanz das Datenpunkt-Objekt korrigiert.
  • Eigene Typescript Module schreiben

    14
    0 Votes
    14 Posts
    1k Views
    HomoranH
    @iob69 sagte in Eigene Typescript Module schreiben: @ticaki Unter der Klasse "Kalender" steht: module.exports = { Kalender}; ist das Leerzeichen gewollt und korrekt?

323

Online

32.9k

Users

82.9k

Topics

1.3m

Posts