我创建了新字段,但是当我尝试更新资源方法“填充”时,它不起作用。甚至没有调用此方法。我的组件看起来像这样
<template>
<default-field :field="field" :errors="errors">
<template slot="field">
<belongs-to
v-for="(resource, key) in selectedResources"
:key="key"
:bidResouce="resource"
:resourceName="field.resourceName"
:associable="field.associableRelationship"
:field="field"
v-model="selectedResources[key]"
@click="selectBid"
>
</belongs-to>
</template>
</default-field>
</template>
<script>
import { FormField, HandlesValidationErrors } from 'laravel-nova'
import BelongsTo from "./BelongsTo";
export default {
components: {BelongsTo},
mixins: [FormField, HandlesValidationErrors],
props: [
'options',
'resourceName',
'resourceId',
'field'
],
data: () => ({
availableResources: [],
search: '',
selectedResources: [],
resourcesCount : 5
}),se{
this.selectedResources = this.field.options;
}
},
/**
* Fill the given FormData object with the field's internal value.
*/
fill(formData) {
console.log('test')
console.log(formData)
formData.append(this.field.attribute, this.selectedResources || '')
},
/**
* Update the field's internal value.
*/
handleChange(value) {
this.value = value
},
selectBid(resourceValue){
}
},
computed: {
defaultValues(){
let data = {};
for(let i =0; i< this.resourcesCount; i++ ){
data[i] = null;
}
return data;
},
countSelected(){
let countNotEmptyItems = 0;
for (let key in this.selectedResources){
if(!!this.selectedResources[key]){
countNotEmptyItems += 1;
}
}
return countNotEmptyItems;
}
},
watch: {
countSelected(newCount){
if(newCount >= this.resourcesCount){
this.resourcesCount++;
this.selectedResources = Object.assign(this.defaultValues, this.selectedResources);
}
}
}
}
</script>
methods: {
/*
* Set the initial, internal value for the field.
*/
setInitialValue() {
let optionsSize = _.size(this.field.options);
if(optionsSize < this.resourcesCount){
this.selectedResources = Object.assign(this.defaultValues, this.field.options);
}else{
this.selectedResources = this.field.options;
}
},
/**
* Fill the given FormData object with the field's internal value.
*/
fill(formData) {
console.log('test')
console.log(formData)
formData.append(this.field.attribute, this.selectedResources || '')
},
/**
* Update the field's internal value.
*/
handleChange(value) {
this.value = value
},
},
computed: {
defaultValues(){
let data = {};
for(let i =0; i< this.resourcesCount; i++ ){
data[i] = null;
}
return data;
},
countSelected(){
let countNotEmptyItems = 0;
for (let key in this.selectedResources){
if(!!this.selectedResources[key]){
countNotEmptyItems += 1;
}
}
return countNotEmptyItems;
}
},
watch: {
countSelected(newCount){
if(newCount >= this.resourcesCount){
this.resourcesCount++;
this.selectedResources = Object.assign(this.defaultValues, this.selectedResources);
}
}
}
}
</script>
请注意,这也是我的自定义组件。该文档指出
在创建或更新资源之前,Nova要求表单上的每个字段用键/值对“填充”传出的FormData对象。每个字段可以根据需要向FormData添加任意数量的元素。这可以在FormField.vue文件的fill方法中完成。