vuejs/docs

SSR guide: add directive transforms

Open

#1,261 创建于 2021年9月28日

在 GitHub 查看
 (1 评论) (0 反应) (0 负责人)Vue (3,223 star) (5,029 fork)user submission
enhancementhelp wanted

描述

The Documentation for writing SSR Transforms for directives, beside a very basic noop example, is nonexistent. I've written an Image Lazy Loading Directive and want to provide an SSR Transform. adding simple properties like src or poster are working flawless. When it comes to adding a style attribute the lack of documentation makes it very hard find a solution. The transform isn't very complex, but i'm struggling to add style='background-image:url()". See the Transform code below

export const vueLazyLoaderSSRTransform = (dir, node, context) => {
    if (node.tag === 'img') {
        return {
            props: [createObjectProperty('src', dir.exp)]
        }
    }

    if (node.tag === 'video') {
        return {
            props: [createObjectProperty('poster', dir.exp)]
        }
    }

    return {
        props: [
            createObjectProperty('style',
                createObjectExpression([
                    createObjectProperty(
                        'background-image',
                        createSimpleExpression('url()', true)
                    )
                ])
            )
        ]
    }
}

It would be great to have a more in depth documentation on SSR Transforms

贡献者指南

SSR guide: add directive transforms · vuejs/docs#1261 | Good First Issue