Heim > Web-Frontend > js-Tutorial > Diskussion über Komponenten und Vorlagen in Vue.js

Diskussion über Komponenten und Vorlagen in Vue.js

黄舟
Freigeben: 2017-10-28 09:29:28
Original
1459 Leute haben es durchsucht

Zusammenfassung: Die

-Direktive ist eine wichtige Funktion in Vue.js. Sie stellt hauptsächlich einen Mechanismus bereit, um Änderungen in Daten dem DOM-Verhalten zuzuordnen. Welche Datenänderungen werden dann dem DOM-Verhalten zugeordnet? Vue.js wird durch Daten gesteuert, sodass wir die DOM-Struktur nicht direkt ändern und es kein ähnliches $('ul').append( '

  • one
  • ') eine solche Operation: Wenn sich die Daten ändern, ändert die Anweisung das DOM mit einer Set-Operation, sodass Sie sich nur auf die Datenänderungen konzentrieren können, ohne DOM-Änderungen und -Status verwalten zu müssen ,

    Vues integrierte Anweisungen

    1. v-bind

    v-bind Es wird hauptsächlich zum Binden von DOM-Elementattributen verwendet.

    bedeutet, dass der tatsächliche Wert des Elementattributs durch das Datenattribut in der VM-Instanz bereitgestellt wird.

    Zum Beispiel:

    <!doctype html>
    <html lang="en">
    <head>
      <meta charset="UTF-8">
      <title>Vue的指令</title>
      <script src="../vue.js"></script>
    </head>
    <body>
    <!-- HTML模版 -->
    <p id="demo">
      <span v-bind:cutomId="id">{{message}}</span>
    </p>
    <script>
      //数据
      let obj ={
        message:"Hello World",
        id:&#39;123&#39;
      };
     //声明式渲染
      var vm = new Vue({
        el:&#39;#demo&#39;,
        data:obj  });
    </script>
    </body>
    </html>
    Nach dem Login kopieren

    v-bind kann als „:“ abgekürzt werden,

    Das obige Beispiel kann als <span :cotomId="id">

    <🎜 abgekürzt werden >Der Effekt ist wie folgt:

    2. v-on

    Bind Event Listener, abgekürzt als @.

    Wir haben es gestern auch verwendet, schauen wir uns die Wirkung in Kürze an

    <!DOCTYPE html>
    <html lang="en">
    <head>
      <meta charset="UTF-8">
      <title>Vue的指令</title>
      <script src="../vue.js"></script>
    </head>
    <body>
      <!-- HTML模版 -->
      <p id="demo">
        <span @click="clickHandle">{{message}}</span>
      </p>
      <script>
        //数据
        let obj = {
          message:"hello Vue"
        };
        //声明式渲染
        var vm = new Vue({
          el:"#demo",
          data:obj,
          methods:{
            clickHandle(){
                alert("click")
                }
          }
        });
      </script>
    </body>
    </html>
    Nach dem Login kopieren
    Die Wirkung ist wie folgt:

    3. v-html

    v-html, der Parametertyp ist string,

    wird zum Aktualisieren von innerHTML verwendet und der

    string

    wird akzeptiert von

    führt keine Kompilierung und andere Vorgänge durch,

    verarbeitet es wie normales HTML

    Der Code lautet wie folgt

    <!DOCTYPE html>
    <html lang="en">
    <head>
      <meta charset="UTF-8">
      <title>Vue的指令</title>
      <script src="../vue.js"></script>
    </head>
    <body>
    <!-- HTML模版 -->
    <p id="demo" v-html="HTML"></p>
    <script>
      //数据
      let obj = {
        HTML:"<p>Hello World</p>"
      };
      var vm = new Vue({
        el:"#demo",
        data:obj  })
    </script>
    </body>
    </html>
    Nach dem Login kopieren

    Der Der Effekt ist wie folgt

    Weitere integrierte Anweisungen finden Sie auf der offiziellen Website: Vue.js-Anweisungen

    Vorlage

    HTML-Vorlage

    DOM-basierte Vorlage, Vorlagen sind alle analysierbar und gültiges HTML

    Interpolation

    Text: Verwenden Sie die „Mustache“-Syntax (double geschweifte Klammern) {{value}}

    Funktion: auf der Instanz ersetzen Attributwert,

    Wenn sich der Wert ändert, wird der interpolierte Inhalt automatisch aktualisiert

    Natives HTML: Doppelte geschweifte Klammern geben Text aus und analysieren das HTML-Attribut

    nicht: Verwenden Sie v-bind für die Bindung, das auf Änderungen reagieren kann

    JavaScript verwendenAusdruck: Sie können einfache Ausdrücke schreiben Die Vorlage ersetzt das hängende Element. Am Element hängende Inhalte werden ignoriert.

    Der Code lautet wie folgt

    Haben Sie überraschende Änderungen bemerkt?

    Der Wurzelknoten kann nur einen haben

    Schreiben Sie die HTML-Struktur in ein Paar Skript-Tags und legen Sie type="X-template" fest
    <!DOCTYPE html>
    <html lang="en">
    <head>
      <meta charset="UTF-8">
      <title>template模板</title>
      <script src="../vue.js"></script>
    </head>
    <body>
      <!--HTML模板-->
      <p id="demo"></p>
      <script>
        //数据
        let obj = {
          html:"<p>String</p>",
          abc:1
        };
        var str = "<p>Hello</p>";
        var vm = new Vue({
          el:"#demo",
          data:obj,
          template:str    })
      </script>
    </body>
    </html>
    Nach dem Login kopieren

    , um den folgenden Effekt zu erzielen:

    ist beim Schreiben in Skript-Tags immer noch relativ begrenzt.

    Wenn andere Dateien ebenfalls diese Struktur haben, kann

    nicht wiederverwendet werden.
    <!DOCTYPE html>
    <html lang="en">
    <head>
      <meta charset="UTF-8">
      <title>template模板</title>
      <script src="../vue.js"></script>
    </head>
    <body>
      <!--HTML模板-->
      <p id="demo">
        <span>vue</span>
      </p>
      <script type="x-template" id="temp">
        <p>
          Hello,{{abc}},
          <span>sunday</span>
        </p>
      </script>
      <script>
        //数据
        let obj = {
          html:"<p>String</p>",
          abc:1
        };
        var vm = new Vue({
          el:"#demo",
          data:obj,
          template:"#temp"
        });
      </script>
    </body>
    </html>
    Nach dem Login kopieren

    Vorlagen-Renderfunktion

    Renderfunktion

    Attribute des Renderoptionsobjekts

    createElement(tag name, {data object}, [child element]);

    Die Unterelemente sind Text oder Arrays

    Lassen Sie uns einen Code zur Demonstration verwenden

    Der Effekt ist wie folgt

    Zusammenfassung

    <!DOCTYPE html>
    <html lang="en">
    <head>
      <meta charset="UTF-8">
      <title>render函数</title>
      <script src="../vue.js"></script>
      <style type="text/css">
        .bg{
          background: #ee0000;
        }
      </style>
    </head>
    <body>
      <p id="demo"></p>
      <script>
        //数据
        let obj = {
        };
        var vm = new Vue({
          el:"#demo",
          data:obj,
          render(createElement){
            return createElement(
              //元素名
              "ul",
              //数据对象
              {
                class:{
                  bg:true
                }
               },
              //子元素
              [
                createElement("li",1),
                createElement("li",2),
                createElement("li",3)
              ]
            );
          }
        })
      </script>
    </body>
    </html>
    Nach dem Login kopieren

    Das obige ist der detaillierte Inhalt vonDiskussion über Komponenten und Vorlagen in Vue.js. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

    Verwandte Etiketten:
    Quelle:php.cn
    Erklärung dieser Website
    Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
    Beliebte Tutorials
    Mehr>
    Neueste Downloads
    Mehr>
    Web-Effekte
    Quellcode der Website
    Website-Materialien
    Frontend-Vorlage