V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
anonymous2351d00
V2EX  ›  Vue.js

Q: vue 的 vnode 如何渲染到 template 里?

  •  
  •   anonymous2351d00 · 2022-12-28 12:33:05 +08:00 · 1688 次点击
    这是一个创建于 705 天前的主题,其中的信息可能已经有所发展或是发生改变。

    intro

    有如下工具类,返回了一个 render 函数使用h创建了vnode

    import { h } from 'vue';
    import SvgIcon from '@/components/custom/SvgIcon.vue';
    
    /**
     * 图标渲染
     * - 用于 vue 的 render 函数
     */
    export const useIconRender = () => {
      interface IconConfig {
        /**
         * 图标名称(iconify 图标的名称)
         * - 例如:mdi-account 或者 mdi:account
         */
        icon?: string;
        /**
         * 本地 svg 图标文件名(assets/svg-icon 文件夹下)
         */
        localIcon?: string;
        /** 图标颜色 */
        color?: string;
        /** 图标大小 */
        fontSize?: number;
      }
    
      interface IconStyle {
        color?: string;
        fontSize?: string;
      }
    
      /**
       * 图标渲染
       * @param config
       * @property icon - 图标名称(iconify 图标的名称), 例如:mdi-account 或者 mdi:account
       * @property localIcon - 本地 svg 图标文件名(assets/svg-icon 文件夹下)
       * @property color - 图标颜色
       * @property fontSize - 图标大小
       */
      const iconRender = (config: IconConfig) => {
        const { color, fontSize, icon, localIcon } = config;
    
        const style: IconStyle = {};
    
        if (color) {
          style.color = color;
        }
        if (fontSize) {
          style.fontSize = `${fontSize}px`;
        }
    
        if (!icon && !localIcon) {
          window.console.warn('没有传递图标名称,请确保给 icon 或 localIcon 传递有效值!');
        }
    
        return () => h(SvgIcon, { icon, localIcon, style });
      };
    
      return {
        iconRender
      };
    };
    
    

    question

    在我的组件里使用了这个函数

      const icon = useIconRender();
      const node = icon.iconRender({ icon: "ant-design:vertical-left" });
    

    可是我要怎么把这个东西渲染到页面上呢?

    7 条回复    2022-12-28 16:47:41 +08:00
    Li83Xi7Gai4
        1
    Li83Xi7Gai4  
       2022-12-28 12:37:45 +08:00
    ```
    components: {
    Icon: {

    }
    }
    ```
    Li83Xi7Gai4
        2
    Li83Xi7Gai4  
       2022-12-28 12:39:59 +08:00   ❤️ 2
    components: {
    Icon: {
    props: {
    icon: {
    required:true,
    type: String,
    }
    },
    render(h) {
    return icon.iconRender({ icon: this.icon });
    }
    }
    }
    shakukansp
        3
    shakukansp  
       2022-12-28 12:59:26 +08:00
    vue 不是 react, template 里的标签必须得是一个组件才能用,所以你不能直接把 render 函数用在 template 里

    return defineComponent({
    render() {
    return () => h(SvgIcon, { icon, localIcon, style });
    }
    })

    script setup
    const Icon = useIconRender()

    template
    <Icon />
    anonymous2351d00
        4
    anonymous2351d00  
    OP
       2022-12-28 13:42:38 +08:00
    @Li83Xi7Gai4 意思就是封装成一个组件吗?
    lwc645089781
        5
    lwc645089781  
       2022-12-28 13:54:12 +08:00
    用这个吧
    <component :is="vnode"></component>
    anonymous2351d00
        6
    anonymous2351d00  
    OP
       2022-12-28 15:59:06 +08:00
    @lwc645089781 我试一下看看
    admc
        7
    admc  
       2022-12-28 16:47:41 +08:00
    页面里引入该函数,注册为组件,然后直接用就行了,典型的函数式组件用法。
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   5750 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 30ms · UTC 03:26 · PVG 11:26 · LAX 19:26 · JFK 22:26
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.