01_sayHello
-Programm verwenden wir jetzt die Vorlagensyntax im <h1>
-Tag, um eine Datei mit dem Namen sayHello Daten, diese Vorlagensyntax ist eigentlich der Syntaxzucker der <code>v-text
-Direktive. Mit anderen Worten, die standardisiertere Syntax des <h1>
-Tags sollte wie folgt lauten: 01_sayHello
程序中,我们现在<h1>
标签中使用模版语法绑定了一个名称为sayHello
的数据,该模版语法实际上是v-text
指令的语法糖。换句话说,该<h1>
标签更规范的语法应该是:<h1 v-text="sayHello"></h1>
{{ data_name }}
这样的模版标记会是更让人舒服的做法。当然了,v-text
指令设置的是当前元素标签下面的文本内容,如果要为标签本身的属性绑定数据,就得要使用v-bind
指令,具体语法是在要设置的标签属性名前面加上v-bind:
前缀。例如,如果想为<img>
标签的src
属性绑定数据,就可以这样做:<img v-bind:src="vueLogo" style="width:200px">
v-bind
指令还有一个简写形式,只需要在要绑定数据的标签属性名之前加一个:
前缀即可。在之前的01_sayHello
程序中,我采用的就是这种形式。在页面元素上绑定了数据之后,接下来就可以在相对应的 JavaScript 脚本中创建 Vue 实例了,这就是我之前在01_sayHello
程序的main.js
文件中编写的内容。这个 Vue 实例对象中至少要定义以下两个成员:el
成员:该成员用于设置当前 Vue 实例所对应的元素容器,这通常是一个<p>
元素,某些情况也可以是 HTML5 提供的<header>
、<footer>
等容器类标签。该成员的值可以是任何一个符合 CSS 选择器语法的字符串,例如#ID
、.CLASSNAME
等。data
成员:该成员用于设置页面元素中绑定的数据,它的值本身也是一个 JSON 格式的对象,该对象的每个成员都对应一个页面元素中绑定的对象,例如在之前的01_sayHello
程序中,我绑定了sayHello
和vueLogo
这两个数据,就必须要在 Vue 对象的data
成员中为为它们设置相应的值。01_sayHello
程序目前只是一个单向显示数据的业务。如果想要让其具备交互能力,还需要为页面元素绑定事件。在 Vue.js 框架中,绑定事件首先要通过v-on
指令来为目标元素标签注册事件处理函数,例如如果我们想在01_sayHello
程序用一个按钮来控制<img>
元素的显示与否,可以将该程序的index.htm
代码修改如下:你好,Vue.js <h1> {{ sayHello }}
<img>
标签中增加了一个v-show
指令,该指令可用于绑定一个布尔类型的数据(即这里的isShow
),以此来决定是否显示其所在的标签。v-bind
指令设置了该标签的value
属性,该属性的值是一个条件表达式,它将根据isShow
的值显示不同的文本。v-on
指令(@
是该指令v-on:
前缀的简写形式)为新增的按钮标签注册了一个名为toggleShow
的单击事件处理函数。main.js
const app = new Vue({ el: '#app', data:{ sayHello: '你好,Vue.js!', vueLogo: 'img/logo.png', isShow: true }, methods:{ toggleShow: function() { this.isShow = !this.isShow; } } });
{{ data_name }}</code > Ein solches Template-Markup wäre komfortabler. Natürlich legt die <code>v-text
-Direktive den Textinhalt unter dem aktuellen Elementlabel fest. Wenn Sie Daten an die Attribute des Labels selbst binden möchten, müssen Sie v-bind< verwenden /code> verwenden, besteht die spezifische Syntax darin, das Präfix <code>v-bind:
vor dem festzulegenden Label-Attributnamen hinzuzufügen. Wenn Sie beispielsweise Daten an das Attribut src
des Tags <img>
binden möchten, können Sie Folgendes tun: <p><!DOCTYPE html> <html lang="zh-cn"> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <meta http-equiv="X-UA-Compatible" content="ie=edge"> <script defer="defer" src="../node_modules/vue/dist/vue.js"></script> <script defer="defer" src="js/main.js"></script> <title>待办事项</title> </head> <body> <p id="app"> <h1>待办事项</h1> <p id="todo"> <ul> <li v-for="( task,index ) in taskList"> <input type="checkbox" v-model="doneList" :value="task"> <label :for="task">{{ task }}</label> <input type="button" value="删除" @click="remove(index)"> </li> </ul> </p> <p id="done" v-if="doneList.length > 0"> <h2>已完成事项</h2> <ul> <li v-for="task in doneList"> <label :for="task">{{ task }}</label> </li> </ul> </p> <input type="text" v-model="newTask" @keyup.enter="addNew"> <input type="button" value="添加新任务" @click="addNew"> </p> </body> </html>
v- bind</code >Die Direktive hat auch eine abgekürzte Form. Sie müssen lediglich ein <code>:
-Präfix vor dem Label-Attributnamen hinzufügen, an den Daten gebunden werden. Im vorherigen 01_sayHello
-Programm habe ich dieses Formular verwendet. Nachdem Sie die Daten an das Seitenelement gebunden haben, können Sie eine Vue-Instanz im entsprechenden JavaScript-Skript erstellen. Dies ist der main.js</code meines vorherigen <code>01_sayHello
-Programms in der Datei. In diesem Vue-Instanzobjekt müssen mindestens die folgenden zwei Mitglieder definiert sein: 🎜el
Mitglied 🎜: Dieses Mitglied wird verwendet, um den Elementcontainer festzulegen, der der aktuellen Vue-Instanz entspricht. Das ist normalerweise ein Element. Das <p>
-Element kann in manchen Fällen auch Container-Tags wie <header>
und <footer> sein. Code> bereitgestellt von HTML5. Der Wert dieses Mitglieds kann eine beliebige Zeichenfolge sein, die der CSS-Selektorsyntax entspricht, z. B. #ID
, .CLASSNAME
usw.
data
member🎜: Dieses Mitglied wird verwendet, um die im Seitenelement gebundenen Daten festzulegen. Sein Wert selbst ist auch ein Objekt im JSON-Format An das in einem Seitenelement gebundene Objekt habe ich beispielsweise im vorherigen 01_sayHello
-Programm die beiden Daten sayHello
und vueLogo
gebunden Legen Sie entsprechende Werte für sie im data
-Member des Vue-Objekts fest. 01_sayHello
derzeit nur ein einseitiges Datenanzeigegeschäft. Wenn Sie es interaktiv gestalten möchten, müssen Sie auch Ereignisse an Seitenelemente binden. Um im Vue.js-Framework ein Ereignis zu binden, müssen Sie zunächst einen Ereignishandler für das Zielelement-Tag über die Direktive v-on
registrieren. Wenn wir beispielsweise einen Ereignishandler in verwenden möchten die Programmschaltfläche 01_sayHello
, um zu steuern, ob das Element <img>
angezeigt wird oder nicht. Sie können den Code index.htm
des Programms ändern wie folgt: 🎜// 程序名称: toDoList // 实现目标: // 1. 学习 v-model、v-for 等指令 // 2. 掌握如何处理用户输入 const app = new Vue({ el: '#app', data:{ newTask: '', taskList: [], doneList: [] }, methods:{ addNew: function() { if(this.newTask !== '') { this.taskList.push(this.newTask); this.newTask = ''; } }, remove: function(index) { if(index >= 0) { this.taskList.splice(index,1); } } } });
v-show
-Direktive zum <img>< hinzugefügt /code>-Tag, das zum Binden eines booleschen Datentyps (d. h. hier isShow
) verwendet werden kann, um zu bestimmen, ob das Etikett dort angezeigt werden soll, wo es sich befindet.
v-bind
wird verwendet, um das Attribut value
der Beschriftung festzulegen. Der Wert dieses Attributs ist ein bedingter Ausdruck, der basierend auf dem Wert von isShow
unterschiedlichen Text anzeigt. v-on
(@
ist die Abkürzung des Präfixes v-on:
des Befehl) als Die neue Schaltflächenbezeichnung registriert einen Klickereignishandler mit dem Namen toggleShow
. main.js
wie folgt:🎜rrreee🎜Hier habe ich hauptsächlich die folgenden Änderungen vorgenommen:🎜data
成员中定义了之前绑定的布尔类型数据isShow
,并将其默认值设置为 true。methods
的成员。该成员用于设置页面元素中注册的事件处理函数,它的值也是一个 JSON 格式的对象。该对象的每个成员都对应一个已在页面元素中用v-on
指令注册的事件处理函数。在这里就是toggleShow
,该函数每次调用都会将isShow
的值取反。隐藏
的按钮。当按钮被单击之后,图标就会消失,按钮上的文本也变成显示。之后,如果该按钮再次被单击,一切又会恢复原状。code
目录下创建一个名为02_toDoList
的目录,并在该目录中创建一个名为index.htm
的文件,其代码如下:<!DOCTYPE html> <html lang="zh-cn"> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <meta http-equiv="X-UA-Compatible" content="ie=edge"> <script defer="defer" src="../node_modules/vue/dist/vue.js"></script> <script defer="defer" src="js/main.js"></script> <title>待办事项</title> </head> <body> <p id="app"> <h1>待办事项</h1> <p id="todo"> <ul> <li v-for="( task,index ) in taskList"> <input type="checkbox" v-model="doneList" :value="task"> <label :for="task">{{ task }}</label> <input type="button" value="删除" @click="remove(index)"> </li> </ul> </p> <p id="done" v-if="doneList.length > 0"> <h2>已完成事项</h2> <ul> <li v-for="task in doneList"> <label :for="task">{{ task }}</label> </li> </ul> </p> <input type="text" v-model="newTask" @keyup.enter="addNew"> <input type="button" value="添加新任务" @click="addNew"> </p> </body> </html>
js
的目录,并在该目录下创建main.js
脚本文件,其代码如下:// 程序名称: toDoList // 实现目标: // 1. 学习 v-model、v-for 等指令 // 2. 掌握如何处理用户输入 const app = new Vue({ el: '#app', data:{ newTask: '', taskList: [], doneList: [] }, methods:{ addNew: function() { if(this.newTask !== '') { this.taskList.push(this.newTask); this.newTask = ''; } }, remove: function(index) { if(index >= 0) { this.taskList.splice(index,1); } } } });
v-model
指令将<input type="text">
标签绑定到newTask
数据中,该指令与v-bind
指令不同的在于,它是一种双向绑定。也就是说,v-model
指令不止可以让 JavaScript 代码中对绑定数据的修改反映到页面元素中,也可以让页面元素获取到的用户输入数据同步到 JavaScript 代码中。在 JavaScript 代码获取到文本框中的用户输入内容之后,我们就可以通过事件处理函数addNew
将其加入到一个名为taskList
的数据列表中,然后将该事件处理函数注册给输入回车和鼠标单击事件。
<p>第二种方式是用单选钮、复选框等选择性元素来获取用户用鼠标勾选的信息。例如在上面这个程序中,我在<p id="todo">
元素中用v-for
指令创建了一系列<input type="checkbox">
,它们都提供v-model
指令将自己双向绑定到了另一个名为doneList
数据列表上。在 Vue.js 框架中,如果一组复选框元素被v-model
指令绑定到了一个列表类型的数据上,那么当这些复选框被选上时,它们的value
属性值就会被自动添加到这个被绑定的数据列表中。
<p>为了证明被选中的复选框被加入到了doneList
数据列表中,我还在页面中添加了一个<p id="done">
元素,并对doneList
数据列表进行了遍历显示。需要说明的是,用于遍历数据列表的v-for
指令主要有两种形式:
v-for="item in dataList"
, dann in der Datenliste ( dataList
) Jedes Datenelement wird während des Durchlaufprozesses einzeln von der Iterationsvariablen (item
) gelesen. v-for="item in dataList"
,这时候数据列表(dataList
)中的每一项数据就会在遍历过程中逐一被迭代变量(item
)说读取。v-for="( item,index ) in dataList"
,这时候数据列表(dataList
)在遍历过程中,每一项数据的值会被item
变量读取,而每一项数据的索引会被index
变量读取。<p id="done">
元素本身,我使用了v-if
指令,它的效果与之前的v-show
指令基本相同,唯一的区别是:v-if
指令会直接在 DOM 树上增加或删除其所在的元素节点,而v-show
指令则是单纯通过其所在元素的style
属性隐藏或显示该元素而已。在执行效率上,v-show
指令要更高效一些。在这里,我们设置了当doneList
列表中没有数据时,程序就直接将<p id="done">
元素从页面中移除,反之则在页面中添加该元素。下面来看一下02_toDoList
Wenn wir den Listenwert und seinen Index gleichzeitig in der Liste abrufen müssen<p>, können wir so schreiben: v-for="(item,index) in dataList" Code>, zu diesem Zeitpunkt Während des Durchlaufprozesses der Datenliste (<code>dataList
) wird der Wert jedes Datenelements von der Variablen item
und dem Index gelesen Jedes Datenelement wird von der index
Variable gelesen. Als letztes ist noch zu beachten, dass ich für das <p id="done">
-Element selbst den v-if
verwendet habe >-Anweisung, ihre Wirkung ist im Grunde die gleiche wie die vorherige v-show
-Anweisung. Der einzige Unterschied besteht darin, dass die v-if
-Anweisung das Element direkt dort hinzufügt oder löscht befindet sich im DOM-Baumknoten, und der Befehl v-show
blendet das Element einfach über das Attribut style
des Elements aus, in dem es sich befindet. Im Hinblick auf die Ausführungseffizienz ist der Befehl v-show
effizienter. Hier legen wir fest, dass das Programm das Element <p id="done">
direkt von der Seite entfernt, wenn keine Daten in der Liste doneList
vorhanden sind. und umgekehrt. Fügen Sie dann das Element zur Seite hinzu. Werfen wir einen Blick auf die Wirkung der Ausführung des Programms 02_toDoList
:
<p> Weitere verwandte kostenlose Lerninhalte: Javascript(Video) 🎜🎜🎜
Das obige ist der detaillierte Inhalt vonVue.js Learning 2: Datengesteuerte Entwicklung. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!