Vue 测试版本:Vue.js v2.5.13
Vue 文档:
元素可以用一个特殊的特性 name 来进一步配置如何分发内容。多个插槽可以有不同的名字。具名插槽将匹配内容片段中有对应 slot 特性的元素。 仍然可以有一个匿名插槽,它是默认插槽,作为找不到匹配的内容片段的备用插槽。
具体应用的时候:
1、匿名插槽的合并行为:
default slot
from parent!
from parent!
window.onload = function() {
Vue.component('myele', {
template: `
`
});
new Vue({
el: '#app'
});
};
效果:内容合并
2、匿名作用域插槽的覆盖行为:
from parent!
from {{props.text}}
from
{{prop.text}}
window.onload = function() {
Vue.component('myele', {
template: `
//即使 text 和上一行一样,也不会报错,开发环境
`
});
new Vue({
el: '#app'
});
};
效果:以靠后的作用域插槽模板为准,绘制了两遍;
3、匿名插槽模板和作用域插槽模板混合:
default slot
from parent!
from {{props.text}}
window.onload = function() {
Vue.component('myele', {
template: `
`
});
new Vue({
el: '#app'
});
};
效果:匿名插槽以匿名作用域插槽模板为准进行渲染,即使你把匿名插槽模板放后面,也是一样的结果;
由此可以看出,最好不要使用匿名、默认插槽,最好使用具名插槽,可以减少不确定性;
参考文档:
https://cn.vuejs.org/v2/guide/components.html#具名插槽
总结
以上所述是小编给大家介绍的Vue匿名插槽与作用域插槽的合并和覆盖行为,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对考高分网网站的支持!
如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢!



