Heim  >  Artikel  >  Web-Frontend  >  Eine Stunde für den Einstieg in Vue-Komponenten (empfohlene Sammlung)

Eine Stunde für den Einstieg in Vue-Komponenten (empfohlene Sammlung)

WBOY
WBOYnach vorne
2021-12-27 19:07:031909Durchsuche

Dieser Artikel vermittelt Ihnen relevantes Wissen über Vue-Komponenten, einschließlich der Instanziierung mehrerer Vue-Objekte, globaler Komponenten und lokaler Komponenten sowie der Übergabe von Werten vom übergeordneten zum untergeordneten Element usw. Ich hoffe, dass er für alle hilfreich ist.

Eine Stunde für den Einstieg in Vue-Komponenten (empfohlene Sammlung)

Erste Einführung in Komponentenanwendungen

Instanziieren Sie mehrere Vue-Objekte.

Verwenden Sie new, um mehrere Vue-Objekte zu erstellen und sie zu benennen. Sie können über Variablen aufeinander zugreifen.
Beispiel: Objekt 2 ändert die Namensvariable von Objekt 1

<!-- 第一个根元素 -->
<div>这里是:{{name}}</div> 

<!-- 第二个根元素 -->
<div>
    <p>这里是:{{name}}</p>
<br>
    <button>change-one-name</button>
    <!-- 点击后修改vue-app-one的name值-->
</div>
 // 第一个vue对象var one = new Vue({
    el:"#vue-app-one",
    data:{
        "name":"ccy1"
    }})

 // 第二个vue对象var two = new Vue({
    el:"#vue-app-two",
    data:{
        "name":"ccy2"
    },
    methods:{
        // 修改vue-app-one的name为'ccy333'
        changeName:function(){
            one.name = 'ccy333'
        }
    }})

Wirkung: Nach dem Klicken ändern Sie „ccy1“ in „ccy333“

Eine Stunde für den Einstieg in Vue-Komponenten (empfohlene Sammlung)

Globale Komponente

Definition und Verwendung

  • Um eine globale Komponente zu definieren, müssen Sie Folgendes angeben die Ändern Sie beim Aufrufen den Namen der Komponente. Dieses Tag wird als Tag-Name verwendet und kann viele Sub-HTML-Tags enthalten. Diese Sub-HTML-Tags werden im Vorlagenattribut der Komponente definiert. Jedes Mal, wenn die Komponente aufgerufen wird, werden die Tags in der Vorlage gerendert. Die Vorlage darf nur ein Stammelement haben Rufen Sie die in data definierten Daten auf
  • Beispiel:
  • Definieren Sie die Komponente:
  • ① Definieren Sie eine Komponente mit dem Namen my-component
  • ② Sie enthält Daten: Name und Methode: changeName
  • ③ Der gerenderte HTML-Effekt hat ein p Tag und enthält eine Schaltfläche. Wenn auf die Schaltfläche geklickt wird, wird der Name geändert Buchstaben, müssen Sie es in Kleinbuchstaben ändern und einen horizontalen Balken verwenden, um die beiden Teile davor und danach zu verbinden, wie definiert. Die Komponente heißt
myComponent
, und wenn sie als Beschriftung geschrieben wird, sollte sie als my- geschrieben werden. Komponente >

// 自定义的全局组件my-component// template中只有一个根元素p标签,里面包含一个button按钮Vue.component('my-component',{
    template:`<p>
        我的名字是:{{name}}
        <button>btn</button>
        </p>`,
    data(){
        return {
            name:'ccy'
        }
    },
    methods:{
        changeName:function(){
            this.name = '安之'
        }
    }})// vue对象1new Vue({
    el:"#vue-app-one",})// vue对象2new Vue({
    el:"#vue-app-two",})

Verwenden von Komponenten:



① Verwenden Sie
unter dem Stammelement, das dem Vue-Objekt entspricht (el spezifizierte Bezeichnung). ② Da es sich um eine definierte globale Komponente handelt, kann es unter jedem Vue-Objekt verwendet werden.

③ Komponenten können sein wiederverwendet und kann mehrfach unter einem Vue-Objekt verwendet werden, und die Komponenten sind unabhängig voneinander ein Objekt wie dieses:
  • Aber in der globalen Komponente können dieselben Daten von mehreren Vue-Objekten verwendet werden, wenn nicht jedes Objekt eine separate Datenkopie verwaltet, wenn ein bestimmtes Vue-Objekt eine Variable ändert In Daten sind andere Vue-Objekte betroffen, wenn sie Daten erhalten. Wenn wir das obige Beispiel als Fallstudie verwenden und die Daten in der Komponente ein Objekt (Referenz) sind, werden die anderen Vue-Objekte nicht geändert Variable mit gleichem Namen; wenn ich die Namensdaten über eines der Vue-Objekte ändere (d. h. auf eine beliebige BTN-Schaltfläche klicke), ändert sich auch der vom anderen Objekt erhaltene Name (das „ccy“ an anderen Schaltflächen ändert sich ebenfalls). Wurde in „Anzhi“ geändert ')
  • Um die Unabhängigkeit der Daten sicherzustellen, d. h.
  • jede Instanz kann eine unabhängige Kopie des zurückgegebenen Objekts verwalten, geben die Daten für jede Instanz eine neu erstellte Kopie zurück. Daten, die von verschiedenen Vue erhalten werden Objekte beeinflussen sich nicht gegenseitig.
In vscode dürfen die Daten in der Komponente kein Objekt sein und es wird ein Fehler gemeldet:

[Vue-Warnung]: Die Option „Daten“

sollte ein sein Funktion
, die einen instanzbezogenen Wert in Komponentendefinitionen zurückgibt.



lokale Komponente

lokale Komponente ist in einem Vue-Objekt registriert,
Eine Stunde für den Einstieg in Vue-Komponenten (empfohlene Sammlung)Nur das Vue-Objekt, das die lokale Komponente registriert hat, kann diese lokale Komponente verwenden

Beispiel:

Lokale Komponentendefinition

:

<p>
    <my-component></my-component>
    <my-component></my-component></p> <p>
    <my-component></my-component></p>
Eine Stunde für den Einstieg in Vue-Komponenten (empfohlene Sammlung)
Lokale Komponente registrieren:

// template仅一个根元素:ulvar msgComponent = {
	 // 数据是自身提供的 (hobbies)
    template:`
  • {{hobby}}
`,     data(){         return {             hobbies:['看剧','看动漫','吃好吃的']         }     }}
Wird in der HTML-Datei verwendet

:

// 仅由注册过该局部组件的vue对象才能使用,此处为p#vue-app-one// 注意命名规范,components中对象的key将会被作为标签名,多个单词拼接的命名需使用横杆法// 可以写成msg-component,此处直接简化了命名为msg,new Vue({
    el:"#vue-app-one",
    components:{
        "msg": msgComponent    }})
Effekt:

Der rot eingekreiste Teil wird vom lokalen gerendert Komponente: Übergeben von Wert/Referenz an Kind: Prop

var titleComponent = {
    props:["title"],
    template:`<p>{{title}}</p>`
    // 所需要的数据title由父组件提供}

在父组件的components属性中注册子组件:

new Vue({
    el:"#vue-app-one",
    components:{
        "msg": msgComponent,
        "titleComponent":titleComponent    },})

在父组件上使用子组件:

<!-- p#vue-app-one为父组件 --><p>
    </p><p>这里是vue-app-one</p>
    <mycomponent></mycomponent>
    <mycomponent></mycomponent>
	<!--使用子组件title-component,并传值"我的爱好:"给子组件-->
    <title-component></title-component>
    <msg></msg>

效果:红框标记处就是父向子传值并展示

Eine Stunde für den Einstieg in Vue-Komponenten (empfohlene Sammlung)

动态传值:v-bind

定义子组件:

var titleComponent = {
    props:["title"],
    template:`<p>{{title}}</p>`}

在父组件的components属性中注册子组件:

new Vue({
    el:"#vue-app-one",
    components:{
        "msg": msgComponent,
        "titleComponent":titleComponent    },
    data(){
        return {
            title:"my hobbies are ",
        }
    }})

使用子组件,通过绑定父组件data中的变量title来实现动态传值:

<!-- p#vue-app-one为父组件 --><p>
    </p><p>这里是vue-app-one</p>
    <mycomponent></mycomponent>
    <mycomponent></mycomponent>
    <!-- 动态绑定title -->
    <title-component></title-component>
    <msg></msg>

效果:红框处就是动态绑定获取数据的展示
Eine Stunde für den Einstieg in Vue-Komponenten (empfohlene Sammlung)
传递数组等复杂数据时,也可以使用v-bind来动态传值,如:
需要向子级传递hobbies数组,在vue实例对象(父)中创建数据hobbies

new Vue({
    el:"#vue-app-one",
    components:{
        "msg": msgComponent,
        "titleComponent":titleComponent    },
    data:{
        title:"my hobbies are ",
        hobbies:['看剧','看动漫','吃好吃的'], //需要向子组件传递的数据
    }})

定义子组件

var msgComponent = {
    template:`
            <p>{{hobby}}</p>            `,
    props:["hobby"],
    data(){
        return {   
        }
    }}

使用子组件

<!-- p#vue-app-one为父组件 --><p>
    </p><p>这里是vue-app-one</p>
    <mycomponent></mycomponent>
    <mycomponent></mycomponent>
    <title-component></title-component>
    <!-- 动态传值:hobbies -->
    <msg></msg>

效果:
Eine Stunde für den Einstieg in Vue-Komponenten (empfohlene Sammlung)
跳回“一点想法”处

子向父:事件传值$emit

        子组件不能通过prop向父组件传递数据,需要使用事件向父组件抛出一个值,告知父组件我需要实现一个功能,由父组件处理这个事件

例子:点击按钮,改变名称chinesename
(由于data变量名不支持chinese-name形式,花括号里不支持chineseName形式,所以这里我都用了小写,此处记录一下,日后学到了新知再来填坑)

先在父组件的data中定义chinesename的初始值:

new Vue({
    el:"#vue-app-one",
    data:{
         chinesename:"anzhi" // chinesename初始值
    }})

创建子组件,并注册事件change-name(就像click事件一样,需要让系统能够辨认这是一个事件并监听,当事件被触发时,执行某项约定好的操作):

  Vue.component('blog-post', {
    props: ['chinesename'],
    template: `
      <p>
        </p><h3>{{ chinesename }}</h3>
        <button>
            修改名字
        </button>
          `
    // blog-post组件包含一个h3,显示chinesename,和一个按钮
    // 点击这个按钮,触发change-name事件,将"ruosu"作为参数传递给指定的处理函数onChangeName
  })

在父组件中使用子组件,定义change-name的处理函数为onChangeName:

<p>
    </p><p>这里是vue-app-one</p>
	<!-- v-bind:通过prop给子组件传递chinesename的初始值 -->
	<!-- v-on:子组件通过$emit给父组件传递新的chinesename的值 -->
	<p>
	      <blog-post></blog-post>
	 </p>

在父组件处定义事件处理函数onChangeName:

new Vue({
    el:"#vue-app-one",
    data:{
          chinesename:"anzhi"
    },
    methods:{
        onChangeName:function(value){
        	// 将chinesename换成传递过来的数据
            this.chinesename=value        }
    }})

效果:
Eine Stunde für den Einstieg in Vue-Komponenten (empfohlene Sammlung)

一点想法

关于父子组件的区分,在此写一点总结,还是日后学了新知识再来填坑 ┗|`O′|┛ 嗷~~

      官网中没有很明确指明两者的定义和区别,在网上搜了一圈,觉得比较多人认可并且好理解的是:

  • el指定的根元素为父组件(使用之处为父组件)
  • vue实例对象也可看做组件

      在前面这些父子传值的例子中,我们可以看到,对于局部组件,我们会在某个html根元素中注册并使用,所以此时el指定的根元素在html文件中是这个局部组件的父组件,局部组件在html使用时便是这个父组件的一份子,承担数据传输的责任
跳转到父向子动态传值案例

Eine Stunde für den Einstieg in Vue-Komponenten (empfohlene Sammlung)
Eine Stunde für den Einstieg in Vue-Komponenten (empfohlene Sammlung)

      再用绕口令说一波,即:title-component组件定义处与使用处,两者身份是不一样的,在定义处,它是局部组件,也是子组件,需注册才能使用;在使用处,它是根元素的包含一部分,根元素为父组件,而“它”,承担着父组件与子组件数据沟通的重任

这个总结在全局组件情况下也适用,使用该全局组件的根元素是父组件,如上面的子向父传值的案例,p#vue-app-one是父组件,作为父子组件沟通的桥梁,全局组件blog-post为子组件
跳转到子向父案例

图示:
Eine Stunde für den Einstieg in Vue-Komponenten (empfohlene Sammlung)


如果是子组件又嵌套了子组件,被嵌套的组件是子子组件,以此类推

建 Verwenden Sie das Gerüstprojekt und verwenden Sie die Komponente und den Wert der Komponente.

Schritte zur Installation des CLI-Gerüsts können Sie in meinem Artikel lesen. Die Verwendung von CLI-Gerüst zum Erstellen eines Projekts ist einfach und schnell. Insbesondere müssen Seiteninhalt und Datenübertragung in .vue-Dateien geschrieben werden, und jede Vue-Datei ist ein Modul.各 Wir können eine bestimmte Funktion durch eine sinnvolle Montage jedes Moduls (Komponente) erfüllen. Die Zusammenarbeit zwischen Komponenten und die Rolle der Vater-Sohn-Übertragung sind hier offensichtlicher. Jede Vue-Datei kann als Komponente betrachtet werden. Wir können die Seite je nach Bedarf in mehrere Teile unterteilen, z. B. in die Navigationsleiste, den mittleren Inhalt und den unteren Teil. Die Implementierung jedes Teils ist in verschiedene Unterkomponenten unterteilt, einschließlich Seitenanzeige und Datenerfassung.

Zum Beispiel eine benutzerdefinierte Blog-Seite:

Die Hauptseite besteht aus der Hauptkomponente der Vue-App, einschließlich der Navigationsleiste, dem mittleren Teil und der unteren Leiste.

  • Die Navigationsleiste vervollständigt durch die Vue-Header-Unterkomponente

  • Zwischeninhalte werden nach Funktion unterteilt

  • Blog hinzufügen: addBlob-Unterkomponente

    Blog anzeigen: showBlob-Unterkomponente
    • Blog ändern: changesBlob-Unterkomponente
    • Klicken Sie, um einzelnen Blog-Inhalt anzuzeigen: singleBlob Unterkomponente
    • Untere Informationen Die Spalte wird durch Vue-Fußzeile vervollständigt
    Zusätzlich zur Hauptseite sind andere Unterteile und Komponenten nach Funktionen unterteilt. Die Hilfshauptseite zeigt

  • Das schematische Diagramm von Die Übergabe des Werts des persönlichen Blogs an das Kind lautet wie folgt:
Jede Unterfunktion besteht aus verschiedenen Komponenten, die zu einer größeren Funktionskomponente zusammengefasst sind.

Klicken Sie, um einen einzelnen Blog anzuzeigen und den Blog zu ändern. Beide Komponenten müssen die Blog-ID abrufen von der Hauptseite aus, um dies anzuzeigen und entsprechend zu bedienen. Dies ist eine typische Wertübertragung von Eltern zu Kind

Das obige ist der detaillierte Inhalt vonEine Stunde für den Einstieg in Vue-Komponenten (empfohlene Sammlung). Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Dieser Artikel ist reproduziert unter:csdn.net. Bei Verstößen wenden Sie sich bitte an admin@php.cn löschen