Groups | Search | Server Info | Keyboard shortcuts | Login | Register [http] [https] [nntp] [nntps]


Groups > de.comp.lang.javascript > #4840

Re: JS Variable von einem Teil zum nächsten übergeben?

Path csiph.com!weretis.net!feeder4.news.weretis.net!feeder5.news.weretis.net!news.solani.org!.POSTED!not-for-mail
From Thomas 'PointedEars' Lahn <PointedEars@web.de>
Newsgroups de.comp.lang.javascript
Subject Re: JS Variable von einem Teil zum nächsten übergeben?
Date Tue, 10 Jan 2017 13:57:48 +0100
Organization PointedEars Software (PES)
Lines 150
Message-ID <2879807.44csPzL39Z@PointedEars.de> (permalink)
References <o4vfhl$t13$1@news.albasani.net> <1795891.oMNUckLgyt@PointedEars.de> <o523rr$vtk$1@news.albasani.net> <11716715.uLZWGnKmhe@PointedEars.de> <o52g21$o01$1@news.albasani.net>
Reply-To Thomas 'PointedEars' Lahn <cljs@PointedEars.de>
Mime-Version 1.0
Content-Type text/plain; charset="UTF-8"
Content-Transfer-Encoding 8Bit
X-Trace solani.org 1484053070 10851 eJwNysENADEIA7CVmh4JMA5CsP8I169lfoLaTZRxueg4oWTWBPIA/UDWfUs0D79sW9Yk5r79AwKMEHo= (10 Jan 2017 12:57:50 GMT)
X-Complaints-To abuse@news.solani.org
NNTP-Posting-Date Tue, 10 Jan 2017 12:57:50 +0000 (UTC)
User-Agent KNode/4.14.2
X-Face %i>XG-yXR'\"2P/C_aO%~;2o~?g0pPKmbOw^=NT`tprDEf++D.m7"}HW6.#=U:?2GGctkL,f89@H46O$ASoW&?s}.k+&.<b';Md8`dH6iqhT)6C^.Px|[=M@7=Ik[_w<%n1Up"LPQNu2m8|L!/3iby{-]A+#YE}Kl{Cw$\U!kD%K}\2jz"QQP6Uqr],./"?;=4v
X-NNTP-Posting-Host eJwNycEBwCAIA8CVQCCYcSqU/UfQ710YFJWOgMfEyOnmfiLTK41bT4d/9b9b2oEkFW4JbbLkAh9xELs=
Cancel-Lock sha1:xnBdS1UADJQMqp0cEeh/PqACt2o=
X-User-ID eJwNyUcBA0EMBDBK9o4rnLjxh3DRVwpjaxdTEz09o2K/0MXt9mL4SadvTaeKPVDm/+bFIZy7sJRD+TNMReUHYqcV2w==
Face iVBORw0KGgoAAAANSUhEUgAAADAAAAAwBAMAAAClLOS0AAAAGFBMVEXTxa4RFk5dUWANED8PFEfy7+MGBiW+n3ZNF/QuAAACaElEQVQ4jVXUwVOcMBQG8Dc7Rc4PUntdWV2uxjDpGaGeozOp1woar4jd5t/v9wLstMwsA/ntlxdCAgUc1hjTc9/JCZfGoo3wG3HdmdAWrIJRHe7GM/TmpY5VFefuVcAkkPbLIaN8rmPmjloyZxgyR3GuJ4K0AGtJ2htz8o7yqikm759fldQXaMpbDzjKAG+8v+AugVTOPO5DOjLvGtUYQwh0CPjnVMyGd+8/GfUB5nLKJDD2aLDh5HYyMDJGDwQIo2ZmZcKbowNmAdB/AzyFhrmF2MHRb0QJJfaAnwGB6orZhoykLzJtGwF/xpYxI1dswomiUj3gTuAIqCn/4C7cULwGNBtwMTk3Y4LfKB5YUaOKBKYtpplm7u0vip8tU1NWWyI/7XdcSuIDoMt6rVHMWT0DbjHPGqDqZVSa6zleLcUTcIKLoMv3ueJluALtAo9B302zPPlrtiVScRdCjXvVh3e3JpYa/jjkuC9N+LrBMlz/eAN4eQijX2EdLo6c5tGGHwLyHFtXk89dDGHwCVhG9T0S/j55AhRZgkMCmUQXJ49TnS1wnQDvw0eAh9ICeMmEFbCnPMFzjAvsWoEWEFdYEx+S0MoUZ1gT1wId8+AF3Bl2OoEu906AUHx5VLw/gXYg/x84loOah/2UYNrgiwSwGO7RfUzVBbx/kgpckumGOi6QirtD6gkLTitbnxNol47S2jVc2vsN5kPqaAHT8uUdAJM4v/DanjYOwmUjWznGfwB7sGtAtor5BgofDuzaRj4kSQAqDakTsKORa3Q3xKi3gE1fhl71KRMqrdZ2AWNNg/YOhQyrVBnb+i+nEg4bsDA+egAAAABJRU5ErkJggg==
Xref csiph.com de.comp.lang.javascript:4840

Show key headers only | View raw


Jan Novak wrote:

> Am 10.01.2017 um 11:11 schrieb Thomas 'PointedEars' Lahn:
>>> Ich nutze das krajee plugin um previews an zu zeigen. Leider habe ich
>>> nichts anderes (freies) gefunden.
>> Nicht gefunden: Wie hast Du gesucht?
> 
> Auf die übliche Weise im Internet nach "preview Plugins" für html/php,
> welche OS sind. Kennst du eine bessere Wahl?

Man könnte/sollte noch den Suchbegriff „JavaScript“ ergänzen.  Da Du aber 
schon Bootstrap gefunden hast, würde ich zuerst in dessen Dokumentation 
suchen statt mit Google.

> Ich habe eine Form, in welcher eine DropDown Box existiert, in welcher 
> Werte (URL's)
         ^^^^^
_URLs_

> stehen

Darin stehen vermutlich _Optionen_ (option-Elemente) mit Dateinamen als 
_Beschriftung_ (Inhalt der option-Elemente), und jede dieser Optionen hat 
einen URL _einer Grafikressource_ als _Wert_ (value-Attribut).

Statt lange darum herumzureden hättest Du also einfach einen Auszug des 
generierten Markups posten können und sollen.

> (welche mit dem Krajee Plugin
                  ^^^^^^^^^^^^^
_“Bootstrap File Input”-Plugin_

> angezeigt werden sollen) und beim Wechsel des Objektes im DropDown
                               ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
bei _Auswahl eines Eintrags_ _des_ _Dropdowns_

> genau diese URL an das Plugin übergeben, um den Preview zu erzeugen.  Ich
> hoffe, das ist jetzt verständlich.

Ja, jetzt schon eher.

(Du unterliegst anscheinend dem Irrtum, dass *ich* nicht wüsste, wovon *ich* 
rede.)

> Eigentlich nichts besonderes.

Richtig: Deshalb …

>> Wie ich schon schrieb: Du brauchst dafür kein Plugin.
> 
> ???

Ich verstehe das jetzt mal als die wesentlich höflichere Frage
„Wie geht das denn, bitte?“.

Du kannst entweder

  a) ein img-Elementobjekt erzeugen, dessen src-Eigenschaft auf den URL 
     setzen und es bei Erfolg dem Dokument hinzufügen:

       var img = document.createElement("img");

       if (img)
       {
         img.onload = function () {
           console.log(this.src, this.width, this.height);
           document.body.appendChild(this);
         };

         img.src = "…";
       }

oder

  b) die src-Eigenschaft eines vorhandenen img-Elementobjekts im Dokument
     setzen:

       var img = document.getElementById("img-foo");

       if (img)
       {
         img.onload = function () {
           console.log(this, this.src, this.width, this.height);

           /* Dokument mit der Information aktualisieren */
         };

         img.src = "…";
       }
       else
       {
         console.error("Fehler auf Layer 8");
       }

Das Erzeugen eines neuen img-Elementobjekts für die neue Grafik bzw. eines, 
welches noch nie in einem gerenderten Elementbaum hing, hat den Vorteil, 
dass seine width- und height-Eigenschaften die richtigen Dimensionen der 
neuen Grafik angeben (falls das unterstützt wird), selbst wenn die width- 
und height-Attribute des vorhandenen img-Elements (anders) angegeben wurden 
(dies lässt sich im Event-Listener des img-Elementobjekts nicht 
unterscheiden).  Man kann dann anschliessend den src-Eigenschaftswerte des 
neuen Objekt der src-Eigenschaft des vorhandenen zuweisen (und braucht 
dessen load-Event nicht mehr zu behandeln).

Im Grunde nichts anderes als das Setzen der src-Eigenschaft eines img-
Elementobjekts macht nämlich das “Bootstrap File Input”-Plugin:

Bei Angabe eines URI in der initialPreview-Eigenschaft des Optionsobjekts 
direkt – sinngemäss:

  img.src = options.initialPreview[0];

Bei Auswahl einer lokalen Datei wird deren Inhalt in einen data-URI 
umgewandelt und dieser der src-Eigenschaft zugewiesen (die lokale Datei
wird vom Browser nicht ohne Benutzeraktion direkt angezeigt – das verbietet 
die Same Origin Policy aus Sicherheitsgründen –, sondern zum Rendern im 
Browser vom Script *nach Benutzeraktion* ausgelesen[1] und 
*rekonstruiert*) – sinngemäss:

  input.onchange = function (event) {
    var reader = new FileReader();

    reader.onload = function (event) {
      img.src = event.target.result;
    };

    reader.readAsDataURL(event.target.files[0]);
  };

<https://developer.mozilla.org/de/docs/Zugriff_auf_Dateien_von_Webapplikationen>

Herausfinden kann man das mit den in Browsern eingebauten oder hinzufügbaren 
Entwicklertools: <http://devtoolsecrets.com/>
 
> Ich will nicht das Rad neu erfinden. Die Möglichkeiten, welche zum
> Beispiel das Krajee Plugin bietet sind sehr schön.
               ^^^^^^^^^^^^^
_“Bootstrap File Input”-Plugin_

> Das möchte ich nicht per Hand nachbauen.

Dann benutze es doch einfach, genau so wie es ich Dir vorgeschlagen hatte.

Wo ist das Problem?

-- 
PointedEars
FAQ: <http://PointedEars.de/faq> | <http://PointedEars.de/es-matrix>
<https://github.com/PointedEars> | <http://PointedEars.de/wsvn/>
Twitter: @PointedEars2 | Please do not cc me./Bitte keine Kopien per E-Mail.

Back to de.comp.lang.javascript | Previous | NextPrevious in thread | Next in thread | Find similar


Thread

JS Variable von einem Teil zum nächsten übergeben? Jan Novak <repcom@gmail.com> - 2017-01-09 08:53 +0100
  Re: JS Variable von einem Teil zum nächsten übergeben? Thomas 'PointedEars' Lahn <PointedEars@web.de> - 2017-01-09 20:44 +0100
    Re: JS Variable von einem Teil zum nächsten übergeben? Jan Novak <repcom@gmail.com> - 2017-01-10 08:52 +0100
      Re: JS Variable von einem Teil zum nächsten übergeben? Thomas 'PointedEars' Lahn <PointedEars@web.de> - 2017-01-10 11:11 +0100
        Re: JS Variable von einem Teil zum nächsten übergeben? Jan Novak <repcom@gmail.com> - 2017-01-10 12:20 +0100
          Re: JS Variable von einem Teil zum nächsten übergeben? Thomas 'PointedEars' Lahn <PointedEars@web.de> - 2017-01-10 13:57 +0100
            Re: JS Variable von einem Teil zum nächsten übergeben? Jan Novak <repcom@gmail.com> - 2017-01-11 10:50 +0100
              Re: JS Variable von einem Teil zum nächsten übergeben? Thomas 'PointedEars' Lahn <PointedEars@web.de> - 2017-01-11 14:08 +0100
                Re: JS Variable von einem Teil zum nächsten übergeben? Jan Novak <repcom@gmail.com> - 2017-01-11 14:31 +0100
                Re: JS Variable von einem Teil zum nächsten übergeben? Thomas 'PointedEars' Lahn <PointedEars@web.de> - 2017-01-11 15:34 +0100
            Re: JS Variable von einem Teil zum nächsten übergeben? Jan Novak <repcom@gmail.com> - 2017-01-11 16:46 +0100
              Re: JS Variable von einem Teil zum nächsten übergeben? Thomas 'PointedEars' Lahn <PointedEars@web.de> - 2017-01-11 18:09 +0100
                Re: JS Variable von einem Teil zum nächsten übergeben? Jan Novak <repcom@gmail.com> - 2017-01-12 10:18 +0100

csiph-web