有人能帮我理解如何控制组件根元素的CSS类和从父组件调用组件的任何CSS类的排序吗?
这是一个演示我注意到的问题的fiddle(以下是片段示例): https://jsfiddle.net/cicsolutions/b6rnaw25/
您会注意到,如果组件具有其根元素上的类,则如果该类是字符串,则Vue的类绑定将该类放在生成的绑定类列表的开头。这是我所期望的,因为组件设置了基本CSS类,然后您可以通过向组件HTML元素添加类来自定义样式。然后Vue将类绑定/连接在一起。
在fiddle中的下一个示例中,我展示了使用动态CSS类(即非静态字符串)的用法。在这些情况下,Vue将组件的根元素类放在绑定类列表的末尾。
我正在开发一个希望其他人使用的组件,因此我想在根元素上设置我的组件类,然后如果有人想要覆盖这些样式,他们可以只需在组件标记上添加自己的类。
我还需要根元素的类是动态的,所以我必须使用数组或对象来处理类绑定。
有人知道为什么Vue在静态类中将组件根css类放在开始处,在动态类中将其放在末尾吗?这对我来说似乎很奇怪,但也许出于某种原因而有意为之。
无论如何,当我需要它成为动态类时,我该如何确保我的组件根元素类始终位于结果绑定类列表中的第一位呢?
Vue.directive('bound-class', (el) => {
const boundClass = el.attributes.class.nodeValue
const boundClassPrintout = document.createElement('div')
boundClassPrintout.innerHTML = 'Resulting Bound Class: ' + boundClass
el.appendChild(boundClassPrintout)
});
// STATIC CSS CLASS -> becomes 1st class in bound class list (expected)
Vue.component('string-test', {
template: `<div class="string-class" v-bound-class><slot></slot></div>`
});
// DYNAMIC CSS CLASS -> becomes last class in bound class list (unexpected)
Vue.component('array-test', {
template: `<div :class="['array-class']" v-bound-class><slot></slot></div>`
});
// DYNAMIC CSS CLASS -> becomes last class in bound class list (unexpected)
Vue.component('object-test', {
template: `<div :class="{ 'object-class': true }" v-bound-class><slot></slot></div>`
});
new Vue({
el: "#app",
computed: {
vueVersion() {
return Vue.version
}
}
})
body {
background: #20262E;
padding: 20px;
}
#app {
background: #fff;
border-radius: 4px;
padding: 20px;
}
h2 {
margin-bottom: 0.75rem;
}
<link href="https://cdn.jsdelivr.net/npm/tailwindcss/dist/tailwind.min.css" rel="stylesheet"/>
<script src="https://cdnjs.cloudflare.com/ajax/libs/vue/2.5.17/vue.js"></script>
<div id="app">
<h2>Vue version: {{ vueVersion }}</h2>
<string-test class="p-2 mb-2 border">Root class (string-class) at beginning (expected)</string-test>
<array-test class="p-2 mb-2 border">Root class (array-class) at end (unexpected)</array-test>
<object-test class="p-2 mb-2 border">Root class (object-class) at end (unexpected)</object-test>
</div>