• Najnowsze pytania
  • Bez odpowiedzi
  • Zadaj pytanie
  • Kategorie
  • Tagi
  • Zdobyte punkty
  • Ekipa ninja
  • IRC
  • FAQ
  • Regulamin
  • Książki warte uwagi

Vue mixin, użycie w komponentcie.

Object Storage Arubacloud
0 głosów
273 wizyt
pytanie zadane 1 marca 2019 w JavaScript przez ShiroUmizake Nałogowiec (46,300 p.)

Mam atomy, które mają wspólne właściwości przykład:

const atomMixin = {
  label: {
    type: String,
    default: '',
  },

  name: {
    type: String,
    default: '',
  },

  value: {
    name: String,
    default: '',
  }
}

Oraz Atom który z nich korzysta:

<template>
  <div>
    <label class="inputTextControler__label" for="search">{{ label }}</label>
    <input class="inputTextControler__input inputTextControler__input--search"
      placeholder="Korepetycje"
      id="search"
      type="text"
      name="search"
      @keyup="handleKeyUp"
    />
  </div>
</template>
<script>
  import AtomMixinProps from '../Mixins/AtomMixin.js';
  export default {
    name: 'AtomInputSearch',
    props: Object.assign({
      searchField: {
        type: String,
        value: ''
      }
    }, AtomMixinProps),
    data() {
      return {
      };
    },
    methods: {
      handleKeyUp(event) {
        this.$store.dispatch('find', {'field': this.searchField, 'value': event.target.value});
        this.$emit('handleKeyUp', event.target.value);
      }
    }
  };
</script>

I object.asign() oczywiście działa, ale z dokumentacji znalazłem coś takiego: Vue.mixin();

I mam pytanko jak z tego korzystać?

W komponentcie, powinen się tak odwłować: this.$parent.$vue.mixin(mixin,1 mixin2) przy created?

1 odpowiedź

+2 głosów
odpowiedź 1 marca 2019 przez niezalogowany
wybrane 1 marca 2019 przez ShiroUmizake
 
Najlepsza

Jeśli chcesz dodać mixin lokalnie

import AtomMixinProps from '../Mixins/AtomMixin.js';
export default {
  name: 'AtomInputSearch',
  mixins: [AtomMixinProps],
  props: {
    searchField: {
      type: String,
      value: ''
    }
  },
  ...
}

Jeśli chcesz dodać mixin do wszystkich komponentów

import AtomMixinProps from '../Mixins/AtomMixin.js';
import Vue from 'vue'

Vue.mixin(AtomMixinProps)

Zwróć uwagę, że mixin z propsami powinien mieć strukturę:

const mixin = {
  props: {
    someProp: {
      type...
    }
  }
}

W komponentcie, powinen się tak odwłować: this.$parent.$vue.mixin(mixin,1 mixin2) przy created?

Nie rozumiem, do czego chcesz się odwoływać?

komentarz 1 marca 2019 przez ShiroUmizake Nałogowiec (46,300 p.)
Do silinika, o właśnie o takie coś mi chodziło .Dzięki :)

Podobne pytania

+1 głos
1 odpowiedź 259 wizyt
pytanie zadane 3 sierpnia 2021 w JavaScript przez mikey Użytkownik (820 p.)
0 głosów
1 odpowiedź 227 wizyt
pytanie zadane 19 września 2020 w JavaScript przez Artek Stary wyjadacz (11,800 p.)
+1 głos
0 odpowiedzi 154 wizyt
pytanie zadane 11 sierpnia 2018 w JavaScript przez mi-20 Stary wyjadacz (13,190 p.)

92,539 zapytań

141,382 odpowiedzi

319,481 komentarzy

61,928 pasjonatów

Motyw:

Akcja Pajacyk

Pajacyk od wielu lat dożywia dzieci. Pomóż klikając w zielony brzuszek na stronie. Dziękujemy! ♡

Oto polecana książka warta uwagi.
Pełną listę książek znajdziesz tutaj.

Akademia Sekuraka

Kolejna edycja największej imprezy hakerskiej w Polsce, czyli Mega Sekurak Hacking Party odbędzie się już 20 maja 2024r. Z tej okazji mamy dla Was kod: pasjamshp - jeżeli wpiszecie go w koszyku, to wówczas otrzymacie 40% zniżki na bilet w wersji standard!

Więcej informacji na temat imprezy znajdziecie tutaj. Dziękujemy ekipie Sekuraka za taką fajną zniżkę dla wszystkich Pasjonatów!

Akademia Sekuraka

Niedawno wystartował dodruk tej świetnej, rozchwytywanej książki (około 940 stron). Mamy dla Was kod: pasja (wpiszcie go w koszyku), dzięki któremu otrzymujemy 10% zniżki - dziękujemy zaprzyjaźnionej ekipie Sekuraka za taki bonus dla Pasjonatów! Książka to pierwszy tom z serii o ITsec, który łagodnie wprowadzi w świat bezpieczeństwa IT każdą osobę - warto, polecamy!

...