Tiven

Tiven

博观而约取,厚积而薄发

天问的个人网站(天问博客),专注于Node.js、Vue.js、React、Vite、Npm、Nginx等大前端技术。不断学习新技术,记录日常开发问题,持续分享coding,极客开源,共同进步。生命不息,奋斗不止... [ Hexo Blog ]

vue警告Non-function value encountered for default slot.


vue + Naive UI 开发项目,使用 h 函数渲染 Naive UI 组件时,出现如下警告:[Vue warn]: Non-function value encountered for default slot. Prefer function slots for better performance.

Naive UI

警告翻译过来就是:「默认插槽为非函数值。推荐使用函数插槽以获得更佳性能。」

代码

在 table 组件中,使用 h 函数渲染 NButton 组件,出现警告:[Vue warn]: Non-function value encountered for default slot. Prefer function slots for better performance.

<script setup>
  import { h, ref, reactive } from 'vue'
  import { NEllipsis } from 'naive-ui'

  const columns = reactive([
    {
      type: 'selection',
      fixed: 'left',
      width: 50,
    },
    {
      title: 'dir',
      key: 'dir',
      width: 100,
      // fixed: 'left',
      render(row) {
        return h(
          NEllipsis,
          {
            'expand-trigger': 'click',
            'line-clamp': 2,
            style: {
              maxWidth: '200px',
            },
          },
          row.dir,
        )
      },
    },
  ])
</script>

解决方案

h 函数的第三参数改为一个对象,并在对象中添加 default 属性,值为一个函数,返回渲染内容。如果有具名插槽,则在对象中添加 插槽名 为属性,值为一个函数返回 h (render) 渲染函数。

render(row) {
  return () => h(
    NEllipsis,
    {
      'expand-trigger': 'click',
      'line-clamp': 2,
      style: {
        maxWidth: '200px',
      },
    },
    {
      default: () => row.dir,
      // 具名插槽
      tooltip: () =>
        h(
          'div',
          {
            style: {
              maxWidth: '300px',
            },
          },
          {
            default: () => row.dir,
          },
        ),
    },
  )
},

欢迎访问:天问博客