i'm pretty new vue , js , i'm bit confused computed methods. follows create props share data parent component. works when sumtotal method executed default value displaying nan on {{sumtotal}}. know how can render int 0 default value sumtotal value.
//parent component <my-colors :myprop="selectedshape.price"></my-colors> </template> <script> import colors './colors.vue'; export default { data() { return { selectedshape: {}, shapes: [{ id: 1, name: "square", price: 4, }, { id: 2, name: "circle", price: 6, }] } }, computed: { totalshape: function() { var totalshape = 0; (var = 0; < this.shapes.length; i++) { if (this.shapes[i].selected) { totalshape += this.shapes[i].price; } } return totalshape; } }, methods: { getselectedshape() { return this.selectedshape; }, } } </script> //child component <v-layout row v-for="color in colors" :key="color.id"> <v-layout > <v-flex > <v-checkbox class="text-xs-right" name="checkbox" v-bind:label="`${color.name}`" v-model="color.checked" light></v-checkbox> </v-flex> </v-layout> <v-layout column> <v-flex > <v-subheader>{{color.price}} €</v-subheader> </v-flex> </v-layout> <v-subheader> {{sumtotal}} €</v-subheader> </v-layout> <script> export default { props: ['myprop'], data: () => ({ colors: [{ id: 1, name: "white", price: 5, }, { id: 2, name: "green", price: 4, }, { id: 3, name: "blue", price: 3, }, { id: 4, name: "red", price: 2, }, { id: 5, name: "purple", price: 1, }, { id: 6, name: "yellow", price: 0, }], }), computed: { total: function() { var total = 0; (var = 0; < this.colors.length; i++) { if (this.colors[i].checked) { total += this.colors[i].price; } } return total; }, sumtotal: function() { var myprop = 0; return this.total + this.myprop; } }, } </script>
when child component renders first time, parent component's data property selectedshape
equal {}
, selectedshape.price
property, passed child, undefined
, when you're invoking sumtotal
method, returns somenumber + undefined
, nan
.
to fix this, should set default price
value selectedshape
property:
selectedshape: { price: 0}
or can change sumtotal
:
sumtotal: function() { return this.total + (this.myprop || 0); }
Comments
Post a Comment