【发布时间】:2018-07-11 13:55:56
【问题描述】:
我有这个简单的 vue 单文件组件
<template>
<v-layout>
<v-flex xs12 sm6 offset-sm3>
<v-card v-bind:color="color" class="white--text">
<v-card-title primary-title>
<div>
<h3 class="headline mb-0">Kangaroo Valley Safari</h3>
<div>{{card_text}}</div>
</div>
</v-card-title>
</v-card>
</v-flex>
</v-layout>
</template>
<script>
import MessageCard from '../components/MessageCard.vue';
const colors = [
'red',
'pink',
'purple',
'indigo',
'green'
];
export default {
data () {
return {
card_text: 'Lorem ipsum dolor sit amet, brute iriure accusata ne mea. Eos suavitate referrentur ad, te duo agam libris qualisque, utroque quaestio accommodare no qui.'
}
},
computed: {
color: function () {
const length = colors.length;
return colors[Math.round(-0.5 + Math.random() * (length + 1))] + ' darken-3';
}
},
components: {
MessageCard
}
}
</script>
问题在于,通过服务器端渲染,我将 color 和 v-card 计算为一种样式,但是当客户端水合作用开始时,计算属性会重新计算,这会改变样式并导致重新渲染。
当然,我可以修复它的修复标签,但我很好奇是否有其他方法可以使其正常工作。
【问题讨论】:
标签: javascript vue.js nuxt.js