Heim > Web-Frontend > Front-End-Fragen und Antworten > Berechnete Eigenschaften, Ereignisüberwachung und bedingtes Rendern der Vue-Grundsyntax (organisiert und gemeinsam genutzt)

Berechnete Eigenschaften, Ereignisüberwachung und bedingtes Rendern der Vue-Grundsyntax (organisiert und gemeinsam genutzt)

WBOY
Freigeben: 2022-01-26 18:03:00
nach vorne
2551 Leute haben es durchsucht

Dieser Artikel fasst die grundlegende Syntax von Vue zusammen, einschließlich berechneter Eigenschaften, Ereignisüberwachung, bedingtem Rendern, Listenrendering und anderen verwandten Themen. Ich hoffe, dass er für alle hilfreich ist.

Berechnete Eigenschaften, Ereignisüberwachung und bedingtes Rendern der Vue-Grundsyntax (organisiert und gemeinsam genutzt)

Vue Hinweis 2: Grundlegende Syntax

1. Interpolation (dynamischer Inhalt)

Mustache-Syntax (doppelte geschweifte Klammern)

Textdaten in Daten in HTML einfügen Stil.

<span>Message: {{ msg }}</span>
<span>{{firstName}}{{lastName}}</span>
<span>{{firstName+lastName}}</span>
<span>{{firstName+""+lastName}}</span>
//使用 JavaScript 表达式
<h2> {{counter*2}}</h2>
<h2>{{ number + 1 }}</h2>
<h2>{{ ok ? 'YES' : 'NO' }}</h2>
<h2>{{ message.split('').reverse().join('') }}</h2>
Nach dem Login kopieren

Befehl

  • v-once: Führen Sie eine einmalige Interpolation durch. Wenn sich die Daten ändern, wird der Inhalt bei der Interpolation nicht aktualisiert
<span v-once>这个将不会改变: {{ msg }}</span>
Nach dem Login kopieren
  • v-html: HTML analysieren und anzeigen
  • v- text: Der Inhaltstext von dom wird im Allgemeinen nicht verwendet und ist nicht flexibel genug. Er deckt den gesamten Inhalt des Tags ab.
  • <h2 v-pre>{{message}} </h2>
    Nach dem Login kopieren
  • Ergebnis: {
{Nachricht}}

v-cloak: Lösen Sie das Problem des Flackerns von {
    {}}, wenn die Vue-Analyse hängen bleibt.
  • Vor der Vue-Analyse hat p das Attribut v-cloak, aber danach Beim Parsen ist dieses Attribut nicht vorhanden. Mit diesem Befehl können Sie also das unkompilierte Mustache-Tag ausblenden, bis die Instanz bereit ist.

      <p id="app" v-cloak>{{message}}</p>
    Nach dem Login kopieren
      <style>
          [v-cloak]{ display:none; }
      </style>
    Nach dem Login kopieren
2. Bindungsattribute (dynamische Attribute)

v-bind wird verwendet, um einen oder mehrere Attributwerte oder an einen anderen zu binden Eine Komponente übergibt Requisitenwerte. Die Abkürzung ist Doppelpunkt :

1. Die src und href des Elements:

1、元素的src和href

<img :src="ImgUrl" /><a :href="aHref">百度</a>
Nach dem Login kopieren

2、class绑定

对象语法

我们可以传给 v-bind:class 一个对象,以动态地切换 class

<p v-bind:class="{ active: isActive }"></p>
Nach dem Login kopieren

上面的语法表示 active 这个 class 存在与否将取决于数据 property isActive 的 truthiness。
你可以在对象中传入更多字段来动态切换多个 class。此外,v-bind:class 指令也可以与普通的 class attribute 共存。

<p class="static" v-bind:class="{ active: isActive, &#39;text-danger&#39;: hasError }"></p>
Nach dem Login kopieren
data: {
  isActive: true,
  hasError: false}
Nach dem Login kopieren

结果渲染为:

<p class="static active"></p>
Nach dem Login kopieren

isActive 或者 hasError 变化时,class 列表将相应地更新。例如,如果 hasError 的值为 true,class 列表将变为 "static active text-danger"
绑定的数据对象不必内联定义在模板里,也可以定义在data

<p v-bind:class="classObject"></p>data: {
  classObject: {
    active: true,
    'text-danger': false
  }
}
Nach dem Login kopieren

渲染的结果和上面一样。我们也可以在这里绑定一个返回对象的计算属性。

<p v-bind:class="classObject"></p>data: {
  isActive: true,
  error: null
},
computed: {
  classObject: function () {
    return {
      active: this.isActive && !this.error,
      'text-danger': this.error && this.error.type === 'fatal'
    }
  }
}
Nach dem Login kopieren

返回对象的方法

<p v-bind:class="IsActive()"></p>data: {
  isActive: true,
  error: null
},
methods: {
  IsActive() {
    return {
      active: this.isActive && !this.error,
      line:isLine
    }
  }
}
Nach dem Login kopieren

数组语法

我们可以把一个数组传给 v-bind:class,以应用一个 class 列表:

<p v-bind:class="[activeClass, errorClass]"></p>
data: {
  activeClass: 'active',
  errorClass: 'text-danger'
}
Nach dem Login kopieren

渲染为:

<p class="active text-danger"></p>
Nach dem Login kopieren

根据条件切换列表中的 class,可以用三元表达式:

<p v-bind:class="[isActive ? activeClass : &#39;&#39;, errorClass]"></p>
Nach dem Login kopieren

这样写将始终添加 errorClass,但是只有在 isActive 是 truthy[1] 时才添加 activeClass

不过,当有多个条件 class 时这样写有些繁琐。所以在数组语法中也可以使用对象语法:

<p v-bind:class="[{ active: isActive }, errorClass]"></p>
Nach dem Login kopieren

3、 style绑定内联样式

对象语法
v-bind:style 的对象语法十分直观——看着非常像 CSS,但其实是一个 JavaScript 对象。CSS property 名可以用驼峰式 (camelCase) 或短横线分隔 (kebab-case,记得用引号括起来) 来命名:

<p v-bind:style="{ color: activeColor, fontSize: fontSize + &#39;px&#39; }"></p> <!--数加字符串隐式转换为字符串类型 -->data: {
  activeColor: 'red',
  fontSize: 30
}
Nach dem Login kopieren

直接绑定到一个样式对象通常更好,这会让模板更清晰:

<p v-bind:style="styleObject"></p>data: {
  styleObject: {
    color: 'red',
    fontSize: '13px'
  }
}
Nach dem Login kopieren

同样的,对象语法常常结合返回对象的计算属性使用。或者方法

<p v-bind:class="classObject"></p> //计算属性<p v-bind:class="classObject()"></p> //方法
Nach dem Login kopieren

数组语法

v-bind:style 的数组语法可以将多个样式对象应用到同一个元素上:

<p v-bind:style="[baseStyles, overridingStyles]"></p>
Nach dem Login kopieren

3、计算属性

在模板中放入太多的逻辑会让模板过重且难以维护,需要对数据进行变化处理后再显示

<p id="example">   {{ message.split('').reverse().join('') }} </p>
Nach dem Login kopieren

基础例子

<p id="example">
  <p>Original message: "{{ message }}"</p>
  <p>Computed reversed message: "{{ reversedMessage }}"</p> <!--按照属性的样式给函数起名,引用函数名不用加括号--></p><script>var vm = new Vue({
  el: '#example',
  data: {
    message: 'Hello'
  },
  computed: {
    // 计算属性的 getter
    reversedMessage: function () {
      // `this` 指向 vm 实例
      return this.message.split('').reverse().join('')
    }
  }})</script>
Nach dem Login kopieren

结果:

Original message: “Hello”

Computed reversed message: “olleH”

这里我们声明了一个计算属性 reversedMessage。我们提供的函数将用作 property vm.reversedMessage 的 getter 函数:

console.log(vm.reversedMessage) // => 'olleH'vm.message = 'Goodbye'console.log(vm.reversedMessage) // => 'eybdooG'
Nach dem Login kopieren

你可以打开浏览器的控制台,自行修改例子中的 vm。vm.reversedMessage 的值始终取决于 vm.message 的值。
你可以像绑定普通 property 一样在模板中绑定计算属性。Vue 知道 vm.reversedMessage 依赖于 vm.message,因此当 vm.message 发生改变时,所有依赖 vm.reversedMessage 的绑定也会更新。而且最妙的是我们已经以声明的方式创建了这种依赖关系:计算属性的 getter 函数是没有副作用 (side effect) 的,这使它更易于测试和理解。

计算属性的 getter和setter

计算属性默认只有 getter,是只读属性,不过在需要时你也可以提供一个 setter:

// ...computed: {
  fullName: {
    // getter
    get: function () {
      return this.firstName + ' ' + this.lastName    },
    // setter
    set: function (newValue) {
      var names = newValue.split(' ')
      this.firstName = names[0]
      this.lastName = names[names.length - 1]
    }
  }}// ...
Nach dem Login kopieren

现在再运行 vm.fullName = 'John Doe' 时,setter 会被调用,vm.firstNamevm.lastName

 fullName:  function () {
      return this.firstName + ' ' + this.lastName }
Nach dem Login kopieren
Nach dem Login kopieren
2. Klassenbindung🎜🎜🎜Objektsyntax🎜🎜🎜Wir können es an v-bind übergeben: Klasse Ein Objekt zum dynamischen Wechseln von Klassen🎜
<p>Reversed message: "{{ reversedMessage() }}"</p>// 在组件中<script>methods: {
  reversedMessage: function () {
    return this.message.split('').reverse().join('')
  }}</script>
Nach dem Login kopieren
Nach dem Login kopieren
🎜Die obige Syntax gibt aktiv an. Das Vorhandensein oder Fehlen dieser Klasse hängt von der Wahrheit der Dateneigenschaft isActive ab . 🎜 Sie können weitere Felder im Objekt übergeben, um dynamisch zwischen mehreren Klassen zu wechseln. Darüber hinaus kann die Direktive v-bind:class auch mit gewöhnlichen Klassenattributen koexistieren. 🎜
<p id="demo">{{ fullName }}</p><script>
    var vm = new Vue({
        el: '#demo',
        data: {
            firstName: 'Foo',
            lastName: 'Bar',
            fullName: 'Foo Bar'
        },
        watch: {
            firstName: function (val) {
                this.fullName = val + ' ' + this.lastName            },
            lastName: function (val) {
                this.fullName = this.firstName + ' ' + val            }
        }</script>
Nach dem Login kopieren
Nach dem Login kopieren
var vm = new Vue({
  el: '#demo',
  data: {
    firstName: 'Foo',
    lastName: 'Bar'
  },
  computed: {
    fullName: function () {
      return this.firstName + ' ' + this.lastName    }
  }})
Nach dem Login kopieren
Nach dem Login kopieren
🎜Das Ergebnis wird wie folgt gerendert: 🎜
 computed: {
	  usertype(){
		  return function (value){
			  var user = ''
			  value === 1 ? user = '学生' : user = '老师'
			  return user		  }
	  }
  }
Nach dem Login kopieren
Nach dem Login kopieren
🎜Wenn sich isActive oder hasError ändert, wird die Klassenliste entsprechend aktualisiert. Wenn beispielsweise hasError als true ausgewertet wird, wird die Klassenliste zu "static active text-danger". 🎜 Das gebundene Datenobjekt muss nicht inline in der Vorlage definiert werden, es kann auch in Daten definiert werden🎜
<p id="example-1">
    <button v-on:click="counter += 1">Add 1</button>
    <button v-on:click="increment"> + </button>
    <button v-on:click="decrement"> - </button>
    <p>The button above has been clicked {{ counter }} times.</p></p><script>
    var example1 = new Vue({
        el: '#example-1',
        data: {
            counter: 0
        },
      methods:{
        increment(){
          this.counter++
        },
        decrement(){
           this.counter--;
        }
      }
    })</script>
Nach dem Login kopieren
Nach dem Login kopieren
🎜Das Rendering-Ergebnis ist das gleiche wie oben. Wir können hier auch eine berechnete Eigenschaft des zurückgegebenen Objekts binden. 🎜
<!--()可有可无-->
<button v-on:click="greet">Greet</button>
<button v-on:click="greet()">Greet</button>
Nach dem Login kopieren
Nach dem Login kopieren
🎜Methoden, die Objekte zurückgeben🎜
<!--方法有参数,调用时没有传参数,但是加了(),形参默认为undefind-->
<button v-on:click="greet()">Greet</button> 
<!--方法有参数,调用时没有传参数,也不加(),返回浏览器产生的Event对象MouseEvent-->
<button v-on:click="greet">Greet</button>
Nach dem Login kopieren
Nach dem Login kopieren
🎜🎜Array-Syntax🎜🎜🎜Wir können ein Array an v-bind:class übergeben, um eine Klassenliste anzuwenden: 🎜
<button @click="btnClick(event)">111</button>
Nach dem Login kopieren
Nach dem Login kopieren
🎜gerendert als: 🎜
<button @click="warn(&#39;Form cannot be submitted yet.&#39;, $event)">
  Submit
</button>
<script>
  methods: {
    warn: function (message, event) {
      // 现在我们可以访问原生事件对象
      if (event) {
        event.preventDefault()
      }
      alert(message)
    }
  }
</script>
Nach dem Login kopieren
Nach dem Login kopieren
🎜To Wechseln Sie die Klassen in der Liste basierend auf Bedingungen. Sie können einen ternären Ausdruck verwenden: 🎜
<button @click="warn">111</button><!--传的是event和undefined-->
<button @click="warn("111",event)">111</button><!--传的是"111"和undefined(报错,找不到event)-->
Nach dem Login kopieren
Nach dem Login kopieren
🎜Wenn Sie so schreiben, wird immer errorClass hinzugefügt, aber nur, wenn isActive wahr ist[1] Fügen Sie einfach activeClass hinzu. 🎜🎜Allerdings ist es etwas umständlich, so zu schreiben, wenn es mehrere bedingte Klassen gibt. Daher kann die Objektsyntax auch in der Array-Syntax verwendet werden: 🎜
<!-- 阻止单击事件继续传播 -->
<a v-on:click.stop="doThis"></a>
  
<!-- 提交事件不再重载页面 -->
<form v-on:submit.prevent="onSubmit"></form>

<!-- 禁止蒙版下的页面滚动-->
<a v-on:touchmove.stop.prevent="doThat"></a> 

<!-- 添加事件监听器时使用事件捕获模式 -->
<!-- 即内部元素触发的事件先在此处理,然后才交由内部元素进行处理 -->
<div v-on:click.capture="doThis">...</div>

<!-- 只当在 event.target 是当前元素自身时触发处理函数 -->
<!-- 即事件不是从内部元素触发的 -->
<div v-on:click.self="doThat">...</div>

<!-- 滚动事件的默认行为 (即滚动行为) 将会立即触发 , 而不会等待 `onScroll` 完成, 这其中包含 `event.preventDefault()` 的情况 -->
<div v-on:scroll.passive="onScroll">...</div>
Nach dem Login kopieren
Nach dem Login kopieren
🎜🎜3. Stilbindung Inline-Stil🎜🎜🎜🎜Objektsyntax🎜🎜v-bind:style Die Objektsyntax ist sehr intuitiv sieht CSS sehr ähnlich, ist aber eigentlich ein JavaScript-Objekt. CSS-Eigenschaftsnamen können in CamelCase oder Kebab-Case benannt werden (denken Sie daran, sie in Anführungszeichen zu setzen): 🎜
<!-- 阻止单击事件继续传播 --> 
<a v-on:click.stop="doThis"></a>
Nach dem Login kopieren
Nach dem Login kopieren
🎜Normalerweise ist es besser, direkt an ein Stilobjekt zu binden, was die Vorlage klarer macht: 🎜
<!-- 提交事件不再重载页面 --><form v-on:submit.prevent="onSubmit"></form>
Nach dem Login kopieren
Nach dem Login kopieren
🎜Ähnlich ist die Objektsyntax Wird häufig in Verbindung mit berechneten Eigenschaften verwendet, die Objekte zurückgeben. Oder die Array-Syntax der Methode 🎜
<!-- 修饰符可以串联 -->
<a v-on:click.stop.prevent="doThat"></a>
<!-- 禁止蒙版下的页面滚动-->
<a v-on:touchmove.stop.prevent="doThat"></a> 
<!-- 只有修饰符 -->
<form v-on:submit.prevent></form>
Nach dem Login kopieren
Nach dem Login kopieren
🎜🎜🎜🎜🎜v-bind:style kann mehrere Stilobjekte auf dasselbe Element anwenden: 🎜
<!-- 只当在 event.target 是当前元素自身时触发处理函数 -->
<!-- 即事件不是从内部元素触发的 --> 
<div v-on:click.self="doThat">...</div>
Nach dem Login kopieren
Nach dem Login kopieren
🎜🎜3. Berechnete Attribute🎜🎜🎜 Zu viel Logik einfügen in der Vorlage führt dazu, dass die Vorlage übergewichtig und schwer zu warten ist. Die Daten müssen vor der Anzeige geändert werden 🎜Hier deklarieren wir eine berechnete Eigenschaft reversedMessage. Die von uns bereitgestellte Funktion wird als Getter-Funktion der Eigenschaft vm.reversedMessage verwendet: 🎜
<Tag @click.native="handleClick">ok</Tag>
Nach dem Login kopieren
Nach dem Login kopieren
🎜Sie können die Browserkonsole öffnen und die VM im Beispiel selbst ändern. Der Wert von vm.reversedMessage hängt immer vom Wert von vm.message ab. 🎜 Sie können berechnete Eigenschaften wie normale Eigenschaften in Vorlagen binden. Vue weiß, dass vm.reversedMessage von vm.message abhängt. Wenn sich also vm.message ändert, gelten alle Abhängigkeiten von vm.reversedMessage wird ebenfalls aktualisiert. Und das Beste daran ist, dass wir diese Abhängigkeit deklarativ erstellt haben: Die Getter-Funktion der berechneten Eigenschaft hat keine Nebenwirkungen, was das Testen und Verstehen erleichtert. 🎜🎜Getter und Setter von berechneten Eigenschaften🎜🎜Berechnete Eigenschaften verfügen standardmäßig nur über Getter, bei denen es sich um schreibgeschützte Eigenschaften handelt, aber Sie können bei Bedarf auch einen Setter bereitstellen: 🎜<div class="code" style="position:relative; padding:0px; margin:0px;"><div class="code" style="position:relative; padding:0px; margin:0px;"><pre class="brush:php;toolbar:false">&lt;!-- 滚动事件的默认行为 (即滚动行为) 将会立即触发 --&gt; &lt;!-- 而不会等待 `onScroll` 完成 --&gt; &lt;!-- 这其中包含 `event.preventDefault()` 的情况 --&gt; &lt;div v-on:scroll.passive=&quot;onScroll&quot;&gt;...&lt;/div&gt;</pre><div class="contentsignin">Nach dem Login kopieren</div></div><div class="contentsignin">Nach dem Login kopieren</div></div>🎜Führen Sie jetzt <code>vm.fullName = 'John Doe ', der Setter wird aufgerufen und <code>vm.firstName und vm.lastName werden entsprechend aktualisiert. 🎜

因为计算属性一般没有setter,所以简写为

 fullName:  function () {
      return this.firstName + ' ' + this.lastName }
Nach dem Login kopieren
Nach dem Login kopieren

计算属性 vs 方法
通过在表达式中调用方法也能达到同样的效果

<p>Reversed message: "{{ reversedMessage() }}"</p>// 在组件中<script>methods: {
  reversedMessage: function () {
    return this.message.split('').reverse().join('')
  }}</script>
Nach dem Login kopieren
Nach dem Login kopieren

两种方式的最终结果确实是完全相同的。然而,不同的是计算属性是基于它们的响应式依赖进行缓存的。只在相关响应式依赖发生改变时它们才会重新求值。这就意味着只要 message 还没有发生改变,多次访问 reversedMessage 计算属性会立即返回之前的计算结果,而不必再次执行函数。
这也同样意味着下面的计算属性将不再更新,相比之下,每当触发重新渲染时,调用方法将总会再次执行函数。

计算属性 vs 侦听属性

Vue 提供了一种更通用的方式来观察和响应 Vue 实例上的数据变动:侦听属性

<p id="demo">{{ fullName }}</p><script>
    var vm = new Vue({
        el: '#demo',
        data: {
            firstName: 'Foo',
            lastName: 'Bar',
            fullName: 'Foo Bar'
        },
        watch: {
            firstName: function (val) {
                this.fullName = val + ' ' + this.lastName            },
            lastName: function (val) {
                this.fullName = this.firstName + ' ' + val            }
        }</script>
Nach dem Login kopieren
Nach dem Login kopieren

上面代码是命令式且重复的。将它与计算属性的版本进行比较:

var vm = new Vue({
  el: '#demo',
  data: {
    firstName: 'Foo',
    lastName: 'Bar'
  },
  computed: {
    fullName: function () {
      return this.firstName + ' ' + this.lastName    }
  }})
Nach dem Login kopieren
Nach dem Login kopieren

计算属性传参

计算属性本身是不能传参的,但是可以通过闭包传参,但是传参之后没有缓存机制了,和methods没有什么区别,所以官网并没有介绍这个

 computed: {
	  usertype(){
		  return function (value){
			  var user = ''
			  value === 1 ? user = '学生' : user = '老师'
			  return user		  }
	  }
  }
Nach dem Login kopieren
Nach dem Login kopieren

4、事件监听

基础

可以用 v-on 指令监听 DOM 事件,并在触发时运行一些 JavaScript 代码。简写@click
许多事件处理逻辑会更为复杂,因此 v-on 还可以接收一个需要调用的方法名称

<p id="example-1">
    <button v-on:click="counter += 1">Add 1</button>
    <button v-on:click="increment"> + </button>
    <button v-on:click="decrement"> - </button>
    <p>The button above has been clicked {{ counter }} times.</p></p><script>
    var example1 = new Vue({
        el: '#example-1',
        data: {
            counter: 0
        },
      methods:{
        increment(){
          this.counter++
        },
        decrement(){
           this.counter--;
        }
      }
    })</script>
Nach dem Login kopieren
Nach dem Login kopieren

参数问题(括号问题)

1、无参

<!--()可有可无-->
<button v-on:click="greet">Greet</button>
<button v-on:click="greet()">Greet</button>
Nach dem Login kopieren
Nach dem Login kopieren

2、有参

<!--方法有参数,调用时没有传参数,但是加了(),形参默认为undefind-->
<button v-on:click="greet()">Greet</button> 
<!--方法有参数,调用时没有传参数,也不加(),返回浏览器产生的Event对象MouseEvent-->
<button v-on:click="greet">Greet</button>
Nach dem Login kopieren
Nach dem Login kopieren

只需要event对象时,

<button @click="btnClick(event)">111</button>
Nach dem Login kopieren
Nach dem Login kopieren

需要event对象,同时也需要其他对象时,可以用特殊变量 $event 把它传入方法:

<button @click="warn(&#39;Form cannot be submitted yet.&#39;, $event)">
  Submit
</button>
<script>
  methods: {
    warn: function (message, event) {
      // 现在我们可以访问原生事件对象
      if (event) {
        event.preventDefault()
      }
      alert(message)
    }
  }
</script>
Nach dem Login kopieren
Nach dem Login kopieren

几种错误写法

<button @click="warn">111</button><!--传的是event和undefined-->
<button @click="warn("111",event)">111</button><!--传的是"111"和undefined(报错,找不到event)-->
Nach dem Login kopieren
Nach dem Login kopieren

事件修饰符

在事件处理程序中调用 event.preventDefault()event.stopPropagation() 是非常常见的需求。尽管我们可以在方法中轻松实现这点,但更好的方式是:方法只有纯粹的数据逻辑,而不是去处理 DOM 事件细节。

为了解决这个问题,Vue.js 为 v-on 提供了事件修饰符。之前提过,修饰符是由点开头的指令后缀来表示的。

<!-- 阻止单击事件继续传播 -->
<a v-on:click.stop="doThis"></a>
  
<!-- 提交事件不再重载页面 -->
<form v-on:submit.prevent="onSubmit"></form>

<!-- 禁止蒙版下的页面滚动-->
<a v-on:touchmove.stop.prevent="doThat"></a> 

<!-- 添加事件监听器时使用事件捕获模式 -->
<!-- 即内部元素触发的事件先在此处理,然后才交由内部元素进行处理 -->
<div v-on:click.capture="doThis">...</div>

<!-- 只当在 event.target 是当前元素自身时触发处理函数 -->
<!-- 即事件不是从内部元素触发的 -->
<div v-on:click.self="doThat">...</div>

<!-- 滚动事件的默认行为 (即滚动行为) 将会立即触发 , 而不会等待 `onScroll` 完成, 这其中包含 `event.preventDefault()` 的情况 -->
<div v-on:scroll.passive="onScroll">...</div>
Nach dem Login kopieren
Nach dem Login kopieren

1.事件修饰符

  • .stop 阻止事件冒泡,调用event.stopPropagation
<!-- 阻止单击事件继续传播 --> 
<a v-on:click.stop="doThis"></a>
Nach dem Login kopieren
Nach dem Login kopieren
  • .prevent 阻止事件默认行为,调用event.preventDefault()
<!-- 提交事件不再重载页面 --><form v-on:submit.prevent="onSubmit"></form>
Nach dem Login kopieren
Nach dem Login kopieren
<!-- 修饰符可以串联 -->
<a v-on:click.stop.prevent="doThat"></a>
<!-- 禁止蒙版下的页面滚动-->
<a v-on:touchmove.stop.prevent="doThat"></a> 
<!-- 只有修饰符 -->
<form v-on:submit.prevent></form>
Nach dem Login kopieren
Nach dem Login kopieren
  • .self 事件绑定的元素本身触发时才触发回调
<!-- 只当在 event.target 是当前元素自身时触发处理函数 -->
<!-- 即事件不是从内部元素触发的 --> 
<div v-on:click.self="doThat">...</div>
Nach dem Login kopieren
Nach dem Login kopieren
  • .once 事件只能触发一次,第二次就不会触发了

不像其它只能对原生的 DOM 事件起作用的修饰符,.once 修饰符还能被用到自定义的组件事件上

  • .native 将一个vue组件变成一个普通的html,使其可以监听click等原生事件,监听组件的原生事件
<Tag @click.native="handleClick">ok</Tag>
Nach dem Login kopieren
Nach dem Login kopieren
  • .passive 能够提升移动端的性能。

不要.passive 和 .prevent 一起使用,因为 .prevent 将会被忽略,同时浏览器可能会向你展示一个警告。请记 住,.passive 会告诉浏览器你想阻止事件的默认行为。

<!-- 滚动事件的默认行为 (即滚动行为) 将会立即触发 -->
<!-- 而不会等待 `onScroll` 完成  -->
<!-- 这其中包含 `event.preventDefault()` 的情况 -->
<div v-on:scroll.passive="onScroll">...</div>
Nach dem Login kopieren
Nach dem Login kopieren
  • .capture
<!-- 添加事件监听器时使用事件捕获模式 --> 
<!-- 即内部元素触发的事件先在此处理,然后才交由内部元素进行处理 --> 
<div v-on:click.capture="doThis">...</div>
Nach dem Login kopieren

使用修饰符时,顺序很重要;相应的代码会以同样的顺序产生。因此,用 v-on:click.prevent.self 会阻止所有的点击,而 v-on:click.self.prevent 只会阻止对元素自身的点击。

不要.passive 和 .prevent 一起使用,因为 .prevent 将会被忽略,同时浏览器可能会向你展示一个警告。请记住,.passive 会告诉浏览器你不想阻止事件的默认行为。

5、条件渲染

基础

v-if 指令用于条件性地渲染一块内容。这块内容只会在指令的表达式返回 truthy 值的时候被渲染。

<h1 v-if="isShow">Vue is awesome!</h1>
<h1 v-else>isShow为false时显示</h1>
Nach dem Login kopieren

<template> 元素上使用 v-if 条件渲染分组

因为 v-if 是一个指令,所以必须将它添加到一个元素上。但是如果想切换多个元素呢?此时可以把一个 <template> 元素当做不可见的包裹元素,并在上面使用 v-if。最终的渲染结果将不包含 <template> 元素。

<template v-if="ok">
  <h1>Title</h1>
  <p>Paragraph 1</p>
  <p>Paragraph 2</p></template>
Nach dem Login kopieren

v-else-if不常用,用计算属性更好

<div v-if="type === &#39;A&#39;">A</div>
<div v-else-if="type === &#39;B&#39;"> B</div>
<div v-else-if="type === &#39;C&#39;">  C</div>
<div v-else>  Not A/B/C</div>
Nach dem Login kopieren

类似于 v-elsev-else-if 也必须紧跟在带 v-if 或者 v-else-if 的元素之后。

key 管理可复用的元素

Vue 会尽可能高效地渲染元素,通常会复用已有元素而不是从头开始渲染。这么做除了使 Vue 变得非常快之外,还有其它一些好处。例如,如果你允许用户在不同的登录方式之间切换:

<template v-if="loginType === &#39;username&#39;">
  <label for="username">Username</label><!--点击label,指向的input获得焦点-->
  <input id="username" placeholder="Enter your username"></template><template v-else>
  <label for="email">Email</label>
  <input id="email" placeholder="Enter your email address"></template>
Nach dem Login kopieren

问题:那么在上面的代码中切换 loginType 将不会清除用户已经输入的内容。

原因:两个模板使用了相同的元素,虚拟DOM渲染时,出于性能考虑<input> 不会被替换掉仅仅是替换了它的 placeholder

解决:添加一个具有唯一值的 key attribute 即可,key不同,不会复用

<template v-if="loginType === &#39;username&#39;">
  <label>Username</label>
  <input placeholder="Enter your username" key="username-input"></template><template v-else>
  <label>Email</label>
  <input placeholder="Enter your email address" key="email-input"></template>
Nach dem Login kopieren

注意,<label> 元素仍然会被高效地复用,因为它们没有添加 key attribute。

v-show

另一个用于根据条件展示元素的选项是 v-show 指令。用法大致一样:

<h1 v-show="ok">Hello!</h1>
Nach dem Login kopieren

不同的是带有 v-show 的元素始终会被渲染并保留在 DOM 中。v-show 只是简单地切换元素的 CSS 属性display

注意,v-show 不支持 <template> 元素,也不支持 v-else

v-if vs v-show

v-if 是“真正”的条件渲染,因为它会确保在切换过程中条件块内的事件监听器和子组件适当地被销毁和重建。

v-if 也是惰性的:如果在初始渲染时条件为假,则什么也不做——直到条件第一次变为真时,才会开始渲染条件块。

相比之下,v-show 就简单得多——不管初始条件是什么,元素总是会被渲染,并且只是简单地基于 CSS 进行切换,当条件为false时,仅仅是将元素的display属性设置为none而已。

一般来说,v-if 有更高的切换开销,而 v-show 有更高的初始渲染开销。

因此,如果需要非常频繁地切换,则使用 v-show 较好;如果在运行时条件很少改变,则使用 v-if 较好。

不推荐同时使用 v-ifv-for。当 v-ifv-for 一起使用时,v-for 具有比 v-if 更高的优先级。

6、列表渲染

6.1 遍历数组

v-for 把一个数组对应为一组元素,v-for 指令需要使用 item in items 形式的特殊语法,其中 items 是源数据数组,而 item 则是被迭代的数组元素的别名

<ul id="example-1">
  <li v-for="item in items" :key="item.message">{{ item.message }}  </li></ul><script>var example1 = new Vue({
  el: '#example-1',
  data: {
    items: [
      { message: 'Foo' },
      { message: 'Bar' }
    ]
  }})</script>
Nach dem Login kopieren

结果:

  • Foo
  • Bar

v-for 块中,我们可以访问所有父作用域的 property。v-for 还支持一个可选的第二个参数,即当前项的索引index。

<ul id="example-2">
  <li v-for="(item, index) in items"> {{ parentMessage }} - {{ index }} - {{ item.message }} </li></ul><script>var example2 = new Vue({
  el: '#example-2',
  data: {
    parentMessage: 'Parent',
    items: [
      { message: 'Foo' },
      { message: 'Bar' }
    ]
  }})</script>
Nach dem Login kopieren

结果:

  • Parent - 0 - Foo
  • Parent - 1 - Bar

你也可以用 of 替代 in 作为分隔符,因为它更接近 JavaScript 迭代器的语法:

<p v-for="item of items"></p>
Nach dem Login kopieren

6.2 遍历对象

你也可以用 v-for 来遍历一个对象的 property。

<!--第一个参数为value--><ul id="v-for-object" class="demo">
  <li v-for="value in object"> {{ value }} </li></ul><!--第二个参数为键名key--><p v-for="(value, name) in object">
  {{ name }}: {{ value }}</p><!--第三个参数为索引index--><p v-for="(value, name, index) in object">
  {{ index }}. {{ name }}: {{ value }}</p><script>new Vue({
  el: '#v-for-object',
  data: {
    object: {
      title: 'How to do lists in Vue',
      author: 'Jane Doe',
      publishedAt: '2016-04-10'
    }
  }})</script>
Nach dem Login kopieren

结果:

  • How to do lists in Vue

  • Jane Doe

  • 2016-04-10

title: How to do lists in Vue

author: Jane Doe

publishedAt: 2016-04-10

\0. title: How to do lists in Vue

\1. author: Jane Doe

\2. publishedAt: 2016-04-10

在遍历对象时,会按 Object.keys() 的结果遍历,但是不能保证它的结果在不同的 JavaScript 引擎下都一致。

6.3 维护状态 (key属性)

当 Vue 正在更新使用 v-for 渲染的元素列表时,它默认使用“就地更新”的策略。如果数据项的顺序被改变,Vue 将不会移动 DOM 元素来匹配数据项的顺序,而是就地更新每个元素,并且确保它们在每个索引位置正确渲染(与虚拟DOM和Diff算法有关)。

这个默认的模式是高效的,但是只适用于不依赖子组件状态或临时 DOM 状态 (例如:表单输入值) 的列表渲染输出

为了给 Vue 一个提示,以便它能跟踪每个节点的身份,从而重用和重新排序现有元素,你需要为每项提供一个唯一 key attribute:

<p v-for="item in items" v-bind:key="item.id">
  <!-- 内容 --></p>
Nach dem Login kopieren

建议尽可能在使用 v-for 时提供 key attribute,除非遍历输出的 DOM 内容非常简单,或者是刻意依赖默认行为以获取性能上的提升。因为它是 Vue 识别节点的一个通用机制,key 并不仅与 v-for 特别关联。

不要使用对象或数组之类的非基本类型值作为 v-forkey,请用字符串或数值类型的值。

6.4 数组更新检测

变更方法(数组的哪些方法是响应式的)

变更方法会变更调用了这些方法的原始数组

Vue 将被侦听的数组的变更方法进行了包裹,所以它们也将会触发视图更新。这些被包裹过的方法包括:

  • push() 加元素,this.names.push("aaa","bbb")

  • pop() 删除数组最后一个元素 ,names.pop()

  • shift()删除数组第一个元素

  • unshift()数组最前面添加元素

  • splice()删除/插入/替换元素

    第一个参数为从哪个位置开始删除/插入/替换元素

    删除元素:第二个参数传入要删除几个元素,不传则删除后面所有元素splice(0,2)

    替换元素:第二个元素传入要替换几个元素,后面跟用于替换的元素splice(0,2,’d’,'2')

    插入元素:第二个元素传入0,后面跟要插入的元素splice(0,0,’d’)

  • sort()数组排序

  • reverse()翻转数组

替换数组(高阶函数filter、map、reduce)

非变更方法,例如 filter()concat()slice()。它们不会变更原始数组,而总是返回一个新数组。你可能认为这将导致 Vue 丢弃现有 DOM 并重新渲染整个列表。幸运的是,事实并非如此。Vue 为了使得 DOM 元素得到最大范围的重用而实现了一些智能的启发式方法,所以用一个含有相同元素的数组去替换原来的数组是非常高效的操作。

由于 JavaScript 的限制,Vue 不能检测数组和对象的变化。深入响应式原理中有相关的讨论。

filter()显示过滤/排序后的结果

回调函数必须返回一个boolean值:

返回true时,函数内部会自动将这次回调的n加入到新的数组;返回false时,函数内部将过滤掉这次的n。

有时,我们想要显示一个数组经过过滤或排序后的版本,而不实际变更或重置原始数据。在这种情况下,可以创建一个计算属性,来返回过滤或排序后的数组。例如:

<li v-for="n in evenNumbers">{{ n }}</li>
<script>
data: {
  numbers: [ 1, 2, 3, 4, 5 ]
},
computed: {
  evenNumbers: function () {
    return this.numbers.filter(function (number) {
      return number % 2 === 0
    })
  }
}
</script>
Nach dem Login kopieren

在计算属性不适用的情况下 (例如,在嵌套 v-for 循环中) 你可以使用一个方法:

<ul v-for="set in sets">
  <li v-for="n in even(set)">{{ n }}</li>
</ul>
<script>
data: {
  sets: [[ 1, 2, 3, 4, 5 ], [6, 7, 8, 9, 10]]
},
methods: {
  even: function (numbers) {
    return numbers.filter(function (number) {
      return number % 2 === 0
    })
  }
}
</script>
Nach dem Login kopieren

map() 映射

let nums=[ 1, 2, 3, 4, 5 ]let nuwnums=nums.map(function(n){
    return n*2})
Nach dem Login kopieren

reduce 数组内元素的汇总

let nums=[ 1, 2, 3, 4, 5 ]//preValue为前一个值,0为初始默认值;n为数组内元素let nuwnums=nums.reduce(function(preValue,n){
    return preValue+n},0)
Nach dem Login kopieren

[在 v-for 里使用值范围]

v-for 也可以接受整数。在这种情况下,它会把模板重复对应次数。

<p>
  <span v-for="n in 10">{{ n }} </span>
</p>
Nach dem Login kopieren

结果:

1 2 3 4 5 6 7 8 9 10

<template>上使用 v-for

类似于 v-if,你也可以利用带有 v-for<template> 来循环渲染一段包含多个元素的内容。比如:

<ul>
  <template v-for="item in items">
    <li>{{ item.msg }}</li>
    <li class="pider" role="presentation"></li>
  </template>
</ul>
Nach dem Login kopieren

v-forv-if 一同使用

注意我们推荐在同一元素上使用 v-ifv-for

当它们处于同一节点,v-for 的优先级比 v-if 更高,这意味着 v-if 将分别重复运行于每个 v-for 循环中。

7、表单输入绑定v-model

基础使用

实现表单元素和数据的双向绑定

<input v-model="message" placeholder="edit me"><p>Message is: {{ message }}</p>data:{
	message:''
}
Nach dem Login kopieren

原理

<input type="text" :value="message" @input="valueChange" /><p>Message is: {{ message }}</p><script>
  data:{
    message:''
  },
	methods:{
     valueChange(event){
       this.message=$event.target.value;
     }
  }      </script>
Nach dem Login kopieren

简写:

<input type="text" :value="message" @input="message=$event.target.value" >
Nach dem Login kopieren

v-model 在内部为不同的输入元素使用不同的 property 并抛出不同的事件:

  • text 和 textarea 元素使用 value property 和 input 事件;
  • checkbox 和 radio 使用 checked property 和 change 事件;
  • select 字段将 value 作为 prop 并将 change 作为事件。

radio单选框

<label for="male">
	<input type="radio" id="male" value="男" v-model="sex">男</label><label for="female">
	<input type="radio" id="female" value="女" v-model="sex">女</label><h2>您选择的性别是{{sex}}</h2>data:{sex:'女'}
Nach dem Login kopieren

data中的sex为默认值,其单选按钮因为双向绑定也会默认选中

单选按钮的互斥:v-model 或者 name=“sex” 放在一个组内

checkbox复选框

单个勾选框,绑定到Boolean值

<label for="agree">
	<input type="checkbox" id="agree" v-model="isAgree">同意协议</label><h2>是否同意协议{{isAgree}}</h2><button :disabeled="!isAgree">
  下一步</button>data:{isAgree:false}
Nach dem Login kopieren

多选框,绑定到数组

<input type="checkbox"  v-model="hobbies">篮球<input type="checkbox"  v-model="hobbies">足球
data:{hobbies:[]}
Nach dem Login kopieren

select选择框

单选

<select v-model="fruit">
  <option value="apple">苹果</option>
  <option value="bannner">香蕉</option></select><h2>选择的水果是{{fruit}}</h2>data:{fruit:''}
Nach dem Login kopieren

多选

<select v-model="fruits" multiple>
  <option value="apple">苹果</option>
  <option value="bannner">香蕉</option></select><h2>选择的水果是{{fruits}}</h2>data:{fruits:[]}
Nach dem Login kopieren

修饰符

.lazy 在输入框输入完内容,光标离开时才更新视图
.trim 过滤首尾空格
.number 自动将用户的输入值转为数值类型。如果先输入数字,那它就会限制你输入的只能是数字;如果先输入字符串,那就相当于没有加.number

用法如下:

<input type="text" v-model.trim="value">
Nach dem Login kopieren

还有很多修饰符比如键盘,鼠标等修饰符

相关推荐:vue.js视频教程

Das obige ist der detaillierte Inhalt vonBerechnete Eigenschaften, Ereignisüberwachung und bedingtes Rendern der Vue-Grundsyntax (organisiert und gemeinsam genutzt). Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Verwandte Etiketten:
vue
Quelle:csdn.net
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