Heim Web-Frontend js-Tutorial 7 Punkte, die beim Einsatz der Vue-Technologie leicht übersehen werden

7 Punkte, die beim Einsatz der Vue-Technologie leicht übersehen werden

May 25, 2018 pm 03:26 PM
Vernachlässigung

Dieses Mal bringe ich Ihnen 7 Punkte, die bei der Verwendung der Vue-Technologie leicht übersehen werden. Was sind die Vorsichtsmaßnahmen, wenn Sie die Vue-Technologie verwenden? Hier sind praktische Fälle.

Vorwort

Dieser Artikel ist eine öffentliche Weitergabe des Vue-Quellcode-Beitrags Dinge, von denen es sich zu lernen lohnt, obwohl ich das für einige Inhalte auch bei der Arbeit mache, übersetze ich hier immer noch das Master-PT, in der Hoffnung, meinen Freunden etwas Hilfe zu bringen.

1. Nutzen Sie die unmittelbare Eigenschaft der Uhr

Das habe ich auch im Projekt geschrieben. Wenn zum Beispiel eine Anfrage einmal ausgeführt werden muss, bevor sie initialisiert wird, und dann ihre Änderungen überwacht werden müssen, schreiben viele Leute das so:

created(){
  this.fetchPostList()
},
watch: {
  searchInputValue(){
    this.fetchPostList()
  }
}
Nach dem Login kopieren

Wir können das Obige wie folgt schreiben:

watch: {
  searchInputValue:{
    handler: 'fetchPostList',
    immediate: true
  }
}
Nach dem Login kopieren

2. Es lohnt sich, von der Komponentenregistrierung zu lernen

Im Allgemeinen sind unsere Komponenten wie folgt geschrieben:

import BaseButton from './baseButton'
import BaseIcon from './baseIcon'
import BaseInput from './baseInput'
export default {
 components: {
  BaseButton,
  BaseIcon,
  BaseInput
 }
}
<BaseInput v-model="searchText" @keydown.enter="search" />
<BaseButton @click="search"> <BaseIcon name="search"/></BaseButton>
Nach dem Login kopieren

Es gibt im Allgemeinen drei Schritte,

Der erste Schritt ist die Einführung,

der zweite Schritt ist die Registrierung,

der dritte Schritt ist die formelle Verwendung,

Dies ist auch die gebräuchlichste und gebräuchlichste Schreibweise. Diese Art der Schreibweise ist jedoch klassisch. Es gibt viele Komponenten, die mehrmals eingeführt und registriert werden müssen, was sehr ärgerlich ist.

Wir können Webpack verwenden, um <a href="http://www.php.cn/wiki/136.html" target="_blank">require<code> <a href="http://www.php.cn/wiki/136.html" target="_blank">require</a>.context() .context( ) zu verwenden. -Methode zum Erstellen Ihres eigenen (Modul-)Kontexts zum Implementieren automatischer dynamischer Anforderungskomponenten.

Die Idee ist: Verwenden Sie in main.js im Ordner src das Webpack, um alle erforderlichen Grundkomponenten dynamisch zu packen.

Der Code lautet wie folgt:

import Vue from 'vue'
import upperFirst from 'lodash/upperFirst'
import camelCase from 'lodash/camelCase'
// Require in a base component context
const requireComponent = require.context(
 ‘./components', false, /base-[\w-]+\.vue$/
)
requireComponent.keys().forEach(fileName => {
 // Get component config
 const componentConfig = requireComponent(fileName)
 // Get PascalCase name of component
 const componentName = upperFirst(
  camelCase(fileName.replace(/^\.\//, '').replace(/\.\w+$/, ''))
 )
 // Register component globally
 Vue.component(componentName, componentConfig.default || componentConfig)
})
Nach dem Login kopieren

Auf diese Weise benötigen wir nur den dritten Schritt, um Komponenten einzuführen:

<BaseInput
 v-model="searchText"
 @keydown.enter="search"
/>
<BaseButton @click="search">
 <BaseIcon name="search"/>
</BaseButton>
Nach dem Login kopieren

3 Einführung von Modulen in Vuex

Für Vuex geben wir den Store wie folgt aus:

import auth from './modules/auth'
import posts from './modules/posts'
import comments from './modules/comments'
// ...
export default new Vuex.Store({
 modules: {
  auth,
  posts,
  comments,
  // ...
 }
})
Nach dem Login kopieren

Sie müssen viele Module einführen und sie dann in Vuex registrieren. Store~~

Streamlined Die Methode ähnelt der oben genannten. Sie verwendet auch require.context(), um die Datei zu lesen . Der Code lautet wie folgt:

import camelCase from 'lodash/camelCase'
const requireModule = require.context('.', false, /\.js$/)
const modules = {}
requireModule.keys().forEach(fileName => {
 // Don't register this file as a Vuex module
 if (fileName === './index.js') return
 const moduleName = camelCase(
  fileName.replace(/(\.\/|\.js)/g, '')
 )
 modules[moduleName] = {
        namespaced: true,
        ...requireModule(fileName),
       }
})
export default modules
Nach dem Login kopieren

Auf diese Weise benötigen wir nur den folgenden Code:

import modules from './modules'
export default new Vuex.Store({
 modules
})
Nach dem Login kopieren

4. Verzögertes Laden von Routen

In Bezug auf die Einführung von Vue habe ich Ich habe es auch bereits in den technischen Punkten und der Zusammenfassung der Vue-Projektrekonstruktion erwähnt. Sie können Komponenten mithilfe der Methoden require oder import() dynamisch laden.

{
 path: '/admin',
 name: 'admin-dashboard',
 component:require('@views/admin').default
}
Nach dem Login kopieren

oder

{
 path: '/admin',
 name: 'admin-dashboard',
 component:() => import('@views/admin')
}
Nach dem Login kopieren

lädt Routen.

5. Aktualisieren Sie die Router-Schlüsselkomponente

Die folgende Szene bricht vielen Programmierern wirklich das Herz ... Lassen Sie mich zunächst zustimmen -router wird zur Implementierung der Routing-Steuerung verwendet. Angenommen, wir schreiben eine Blog-Website und die Anforderung besteht darin, von /post-haorooms/a nach /post-haorooms/b zu springen. Dann stellten wir überraschend fest, dass die Daten nach dem Seitensprung nicht aktualisiert wurden? ! Der Grund dafür ist, dass der Vue-Router „intelligent“ erkannt hat, dass es sich um dieselbe Komponente handelt, und dann beschlossen hat, diese Komponente wiederzuverwenden, sodass die Methode, die Sie in der erstelltenFunktion geschrieben haben, überhaupt nicht ausgeführt wurde. Die übliche Lösung besteht darin, Änderungen in $route zu überwachen, um die Daten wie folgt zu initialisieren:

data() {
 return {
  loading: false,
  error: null,
  post: null
 }
}, 
watch: {
 '$route': {
  handler: 'resetData',
  immediate: true
 }
},
methods: {
 resetData() {
  this.loading = false
  this.error = null
  this.post = null
  this.getPost(this.$route.params.id)
 },
 getPost(id){
 }
}
Nach dem Login kopieren

Der Fehler ist behoben, aber ist es zu unelegant, jedes Mal so zu schreiben? Wir halten uns an den Grundsatz „Lazy if you can“ und hoffen, dass der Code so geschrieben wird:

data() {
 return {
  loading: false,
  error: null,
  post: null
 }
},
created () {
 this.getPost(this.$route.params.id)
},
methods () {
 getPost(postId) {
  // ...
 }
}
Nach dem Login kopieren

Lösung: Fügen Sie einen eindeutigen Schlüssel zur Router-Ansicht hinzu, sodass, selbst wenn es sich um eine öffentliche Komponente handelt, Solange sich die URL ändert, wird sie neu erstellt. Erstellen Sie diese Komponente.

<router-view :key="$route.fullpath"></router-view>
Nach dem Login kopieren

Hinweis: Nach meiner persönlichen Erfahrung wird dies im Allgemeinen in Unterrouten verwendet, um eine große Anzahl von Neuzeichnungen nicht zu vermeiden. Vorausgesetzt, dass dieses Attribut zum Stammverzeichnis von app.vue hinzugefügt wird Jedes Mal, wenn Sie klicken, um die Adresse zu ändern, wird sie neu gezeichnet, der Gewinn ist es trotzdem nicht wert!

6. Das einzige Komponentenstammelement

Das Szenario ist wie folgt:

(Stattdessen wird ein Wert ausgegeben einer Fehlerinstanz)
Fehler beim Kompilieren der Vorlage:


  - Component template should contain exactly one root element.
    If you are using v-if on multiple elements, use v-else-if
    to chain them instead.

模板中p只能有一个,不能如上面那么平行2个p。

例如如下代码:

<template>
 <li
  v-for="route in routes"
  :key="route.name"
 >
  <router-link :to="route">
   {{ route.title }}
  </router-link>
 </li>
</template>
Nach dem Login kopieren

会报错!

我们可以用render函数来渲染

functional: true,
render(h, { props }) {
 return props.routes.map(route =>
  <li key={route.name}>
   <router-link to={route}>
    {route.title}
   </router-link>
  </li>
 )
}
Nach dem Login kopieren

七、组件包装、事件属性穿透问题

当我们写组件的时候,通常我们都需要从父组件传递一系列的props到子组件,同时父组件监听子组件emit过来的一系列事件。举例子:

//父组件
<BaseInput 
  :value="value"
  label="密码" 
  placeholder="请填写密码"
  @input="handleInput"
  @focus="handleFocus>
</BaseInput>
//子组件
<template>
 <label>
  {{ label }}
  <input
   :value="value"
   :placeholder="placeholder"
   @focus=$emit(&#39;focus&#39;, $event)"
   @input="$emit(&#39;input&#39;, $event.target.value)"
  >
 </label>
</template>
Nach dem Login kopieren

这样写很不精简,很多属性和事件都是手动定义的,我们可以如下写:

<input
  :value="value"
  v-bind="$attrs"
  v-on="listeners"
>
computed: {
 listeners() {
  return {
   ...this.$listeners,
   input: event => 
    this.$emit('input', event.target.value)
  }
 }
}
Nach dem Login kopieren

$attrs包含了父作用域中不作为 prop 被识别 (且获取) 的特性绑定 (class 和 style 除外)。当一个组件没有声明任何 prop 时,这里会包含所有父作用域的绑定,并且可以通过 v-bind="$attrs" 传入内部组件。

$listeners包含了父作用域中的 (不含 .native 修饰器的) v-on 事件监听器。它可以通过 v-on="$listeners" 传入内部组件。

相信看了本文案例你已经掌握了方法,更多精彩请关注php中文网其它相关文章!

推荐阅读:

怎样对webpack模块进行热替换

Angular入口组件与声明式组件案例对比

Das obige ist der detaillierte Inhalt von7 Punkte, die beim Einsatz der Vue-Technologie leicht übersehen werden. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

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

Heiße KI -Werkzeuge

Undresser.AI Undress

Undresser.AI Undress

KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover

AI Clothes Remover

Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool

Undress AI Tool

Ausziehbilder kostenlos

Clothoff.io

Clothoff.io

KI-Kleiderentferner

AI Hentai Generator

AI Hentai Generator

Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

R.E.P.O. Energiekristalle erklärten und was sie tun (gelber Kristall)
3 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Beste grafische Einstellungen
3 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. So reparieren Sie Audio, wenn Sie niemanden hören können
3 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25: Wie man alles in Myrise freischaltet
3 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌

Heiße Werkzeuge

Notepad++7.3.1

Notepad++7.3.1

Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version

SublimeText3 chinesische Version

Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1

Senden Sie Studio 13.0.1

Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6

Dreamweaver CS6

Visuelle Webentwicklungstools

SublimeText3 Mac-Version

SublimeText3 Mac-Version

Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Ersetzen Sie Stringzeichen in JavaScript Ersetzen Sie Stringzeichen in JavaScript Mar 11, 2025 am 12:07 AM

Detaillierte Erläuterung der Methode für JavaScript -Zeichenfolge und FAQ In diesem Artikel werden zwei Möglichkeiten untersucht, wie String -Zeichen in JavaScript ersetzt werden: Interner JavaScript -Code und interne HTML für Webseiten. Ersetzen Sie die Zeichenfolge im JavaScript -Code Die direkteste Möglichkeit ist die Verwendung der Ersatz () -Methode: str = str.replace ("find", "ersetzen"); Diese Methode ersetzt nur die erste Übereinstimmung. Um alle Übereinstimmungen zu ersetzen, verwenden Sie einen regulären Ausdruck und fügen Sie das globale Flag G hinzu:: STR = Str.Replace (/fi

Wie erstelle ich meine eigenen JavaScript -Bibliotheken? Wie erstelle ich meine eigenen JavaScript -Bibliotheken? Mar 18, 2025 pm 03:12 PM

In Artikel werden JavaScript -Bibliotheken erstellt, veröffentlicht und aufrechterhalten und konzentriert sich auf Planung, Entwicklung, Testen, Dokumentation und Werbestrategien.

Wie optimiere ich den JavaScript -Code für die Leistung im Browser? Wie optimiere ich den JavaScript -Code für die Leistung im Browser? Mar 18, 2025 pm 03:14 PM

In dem Artikel werden Strategien zur Optimierung der JavaScript -Leistung in Browsern erörtert, wobei der Schwerpunkt auf die Reduzierung der Ausführungszeit und die Minimierung der Auswirkungen auf die Lastgeschwindigkeit der Seite wird.

Wie debugge ich den JavaScript -Code effektiv mithilfe von Browser -Entwickler -Tools? Wie debugge ich den JavaScript -Code effektiv mithilfe von Browser -Entwickler -Tools? Mar 18, 2025 pm 03:16 PM

In dem Artikel werden effektives JavaScript -Debuggen mithilfe von Browser -Entwickler -Tools, der Schwerpunkt auf dem Festlegen von Haltepunkten, der Konsole und der Analyse der Leistung erörtert.

10 Möglichkeiten, Ihre JQuery -Leistung sofort zu erhöhen 10 Möglichkeiten, Ihre JQuery -Leistung sofort zu erhöhen Mar 11, 2025 am 12:15 AM

Dieser Artikel beschreibt zehn einfache Schritte, um die Leistung Ihres Skripts erheblich zu steigern. Diese Techniken sind unkompliziert und für alle Fähigkeiten anwendbar. Bleiben Sie auf dem Laufenden: Verwenden Sie einen Paketmanager wie NPM mit einem Bundler wie Vite, um sicherzustellen

Verwenden Sie den Pass mit Folge und MySQL Verwenden Sie den Pass mit Folge und MySQL Mar 11, 2025 am 11:04 AM

FECKERIZE ist ein vielversprechender node.js orm. Es kann mit Postgresql, MySQL, Mariadb, SQLite und MSSQL verwendet werden. In diesem Tutorial werden wir die Authentifizierung für Benutzer einer Web -App implementieren. Und wir werden Passport verwenden, die beliebte Authentifizierung Middlew

So bauen Sie einen einfachen JQuery Slider So bauen Sie einen einfachen JQuery Slider Mar 11, 2025 am 12:19 AM

In diesem Artikel werden Sie mit der JQuery -Bibliothek ein einfaches Bildkarousel erstellen. Wir werden die BXSLIDER -Bibliothek verwenden, die auf JQuery basiert und viele Konfigurationsoptionen zum Einrichten des Karussells bietet. Heutzutage ist Picture Carousel zu einem Muss auf der Website geworden - ein Bild ist besser als tausend Wörter! Nachdem Sie sich entschieden haben, das Bild -Karussell zu verwenden, ist die nächste Frage, wie Sie es erstellen. Zunächst müssen Sie hochwertige, hochauflösende Bilder sammeln. Als nächstes müssen Sie ein Bildkarousel mit HTML und einem JavaScript -Code erstellen. Es gibt viele Bibliotheken im Web, die Ihnen helfen können, Karussell auf unterschiedliche Weise zu erstellen. Wir werden die Open -Source -BXSLIDER -Bibliothek verwenden. Die BXSLIDER -Bibliothek unterstützt reaktionsschnelles Design, sodass das mit dieser Bibliothek gebaute Karussell an alle angepasst werden kann

Wie verwende ich Quellkarten zum Debuggen, um den JavaScript -Code zu debuggen? Wie verwende ich Quellkarten zum Debuggen, um den JavaScript -Code zu debuggen? Mar 18, 2025 pm 03:17 PM

In dem Artikel wird erläutert, wie Quellkarten zum Debuggen von JavaScript verwendet werden, indem er auf den ursprünglichen Code zurückgegeben wird. Es wird erläutert, dass Quellenkarten aktiviert, Breakpoints eingestellt und Tools wie Chrome Devtools und WebPack verwendet werden.

See all articles