Как сделать компонент с параметрами?

Привет! Я новичок в vue. Столкнулся с проблемой, скорее всего, элементарной. Но никак не могу найти решение.
Пытаюсь сделать библиотеку компонентов при помощи vue cli.
Сделал простой компонент "список":
App.vue
<template>
  <div id="app">
    <OptionsList v-bind:options="options" />	
  </div>  
</template>

<script>
import OptionsList from './components/OptionsList.vue'
export default {
  name: 'app',  
  components: {    
	OptionsList
  },  
  data: function() {
		return {			
			options: [{id:0, value: 'first'},
				{id:1, value: 'second'}
			]
		}
	}
}</script>


OptionsList.vue
<template>
	<div>
		<ul>
			<OptionsItem 
				v-for="(item, index) in options" 
				v-bind:idx="index"
				v-bind:key="index"
				v-bind:errors="errors"
				v-bind:len="optionsCount"
				v-bind:option="item"
				v-bind:readOnly="readOnly"
				v-on:del-click="delClick($event)"
				v-on:sort-click="sortClick($event)"/>
		</ul>
		<button v-on:click.prevent="addClick">Добавить</button></div>
</template>

<script>

import OptionsItem from './OptionsItem.vue'

export default {
	name: 'OptionsList',
	components: {
		OptionsItem
	},
	props: {
		options: Array,
		readOnly: Boolean
	},
	data: function() {
		return {			
			errors: []
		}
	},
	computed: {
		optionsCount: function() {
			return this.options.length;
		}
	},
	methods: {
		addClick: function () {
			window.console.log('add click');		
			this.options.push({ id: this.options.length,  value: null });
		},
		delClick: function (idx) {
			window.console.log('del click' + idx);
			this.options.splice(idx, 1);
			this.options.forEach((item, idx) => { item.id = idx; });
		},
		sortClick: function (param) {
			if (param.dir === 1) {
				this.options[param.idx].id--;
				this.options[param.idx - 1].id++;
			} else {
				this.options[param.idx].id++;
				this.options[param.idx + 1].id--;
			}
			this.options.sort(function(a, b) {			
				return b.id >  a.id ? -1 : 1;
			});		
		}
	}
}
</script>


OptionsItem.vue
<template>
<li>
	<span>{{idx + 1}}</span>
	<input type="text" v-bind:readOnly="readOnly" v-bind:class="{error: errors.find(e=>{return e.field=='option_'+idx;})}" v-model="option.value">
	<button v-if="!readOnly" v-on:click.prevent="$emit('del-click', idx)">Удалить</button>
	<button v-if="!readOnly && idx > 0" v-on:click.prevent="$emit('sort-click', {idx: idx, dir: 1})">&uarr;</button>
	<button v-if="!readOnly && idx < len - 1" v-on:click.prevent="$emit('sort-click', {idx: idx, dir: 0})">&darr;</button>
</li>
</template>

<script>
export default {
  name: 'OptionsItem',
  props: {
    option: Object,
	idx: Number,
	len: Number,
	errors: Array,
	readOnly: Boolean
  }
}
</script>


При отладке компонент работает нормально.
Собираю библиотеку $ vue-cli-service build --mode production --dest dist --target lib --name OptionsForm --dashboard
Библиотека нормально собирается и работает.
В demo.html вызов компонента выглядит так:
<div id="app">
  <demo></demo>
</div>

<script>
new Vue({
  components: {
    demo: OptionsForm
  }
}).$mount('#app');
</script>


Никак не могу разобраться как сделать так, чтоб в компонент можно было передать параметры..
Типа:
<script>
new Vue({
  components: {
    demo: OptionsForm
  }
}).$mount('#app');
OptionsForm.options = [{id:0, value: 'first'}, {id:1, value: 'second'}];
</script>
  • Вопрос задан
  • 257 просмотров
Решения вопроса 1
@hpa777 Автор вопроса
Если кому интересно, ответ здесь https://github.com/wuruoyun/vue-component-lib-starter
Ответ написан
Комментировать
Пригласить эксперта
Ваш ответ на вопрос

Войдите, чтобы написать ответ

Войти через центр авторизации
Похожие вопросы
19 апр. 2024, в 05:01
999999 руб./за проект
19 апр. 2024, в 03:52
1000 руб./за проект
19 апр. 2024, в 03:01
1000 руб./за проект