У меня есть пользовательский компонент:
<template>
<div class="form-group">
<label for="desc">{{label}}</label>
<input id="desc" type="text" class="form-control input-sm"
:name="label"
:readonly="readonly"
v-bind:value="value"
v-on:input="$emit('input', $event.target.value)"
v-validate="validate"
/>
<div class="error-feedback">{{ errors.first(label) }}</div>
{{readonly}}<!-- debugging -->
</div>
</template>
<script>
export default {
name: 'FormGroup',
props: {
label: String,
value: String,
readonly: String,
validate: String
},
data: function() {
return {
}
}
}
</script>
<style scoped>
.error-feedback {
color: #cc3333;
}
</style>
Когда я звоню с:
<FormGroup label="Channel" readonly="device_config.enabled" validate="required" v-model="device_config.some_setting" />
Пользовательский компонент получает свойство readonly в виде буквенной строки "device_config.some_setting"
, а не значение, содержащееся в device_config.some_setting
.
Как я могу заставить свой пользовательский компонент сделать поле доступным только для чтения в зависимости от значения в модели вызывающего компонента, которое передается?