0

0

立即吸引用户:在 React SPA 中嵌入交互式演示

聖光之護

聖光之護

发布时间:2025-01-10 08:13:47

|

734人浏览过

|

来源于php中文网

原创

如果一张图片胜过千言万语,那么一个交互式演示的价值……岂止百万?

您是否喜欢通过冗长的说明文字来了解应用程序的功能?可能不会。我不想为我的最新项目 Wanna 撰写过多的赘述。因此,我寻求了一种更具吸引力的解决方案:将我的应用程序嵌入到登录页面中,供用户直接体验!

立即吸引用户:在 React SPA 中嵌入交互式演示

这段 GIF 包含 263 帧,所以我猜它相当于 263,000 个字

实现

借助 React 的可组合性,我们几乎可以简单地渲染根应用程序组件并结束:

export const interactiveDemo = () => {
    return (
        
    )
}

但是,您可能会遇到一些问题:

  1. 演示应用程序的导航会跳转到真实应用程序。
  2. 演示应用程序会检索真实数据,这可能导致失败或无法有效地展示其功能。
  3. 用户可能不清楚他们正在查看的是什么。

让我们逐一解决这些问题。我使用了 React Router v6 和 Apollo GraphQL,但无论您使用何种技术,这些概念都是通用的。

导航

为了将演示应用程序的导航与真实应用程序隔离开来,我们将其封装在另一个导航提供程序中:

+import { MemoryRouter, UNSAFE_LocationContext } from 'react-router'

export const interactiveDemo = () => {
    return (
+       // 解决嵌套 MemoryRouter 在 BrowserRouter 内的问题。
+       // https://github.com/remix-run/react-router/issues/7375
+       
+           
+       
    )
}

请注意,我们使用了 MemoryRouter,以便在演示内部导航时浏览器保持在同一页面上。

数据

为了向演示应用程序提供模拟数据,我们在客户端应用程序内维护一个模拟的“后端”,并通过模拟客户端或服务器(取决于您的实现)为其提供服务。这最大限度地减少了对应用程序其余部分的影响,甚至允许我们使用演示进行手动测试——在快速迭代时非常方便。

我使用了 mock-apollo-client;对于 REST 或 tRPC,您可以使用类似 nock 的工具。这些工具通常用于自动化测试,但它们正是我们所需要的。

中解商务通
中解商务通

实时捕捉 一旦访问者打开您的网站,系统会立即显示,这时您就可以查看用户的信息,如:来自搜索引擎关键词、友情链接或直接访问;访问者的IP地址,所在地区,正在访问哪个网页;以及访问者使用的操作系统、浏览器、显示器屏幕分辨率颜色深度等。 主动出击 变被动为主动,可以主动邀请访问者进行洽谈勾通,帮助客户深入了解您的企业和产品,同时获得对方的采购意向、联系方式等信息。 互动交流 主动销售和在线客服合二为一,

下载

首先,我们创建一个模拟客户端,其请求处理程序以模仿真实后端的方式查询和修改演示数据:

import { InMemoryCache } from '@apollo/client'
import { createMockClient, createMockSubscription } from 'mock-apollo-client'
import { useMemo, useState } from 'react'
// 您的客户端发送到真实服务器的 GraphQL 文档
import getFriends from '../../gql/getFriends.gql'
import addFriend from '../../gql/addFriend.gql'

// 简化示例
export const useDemoClient = () => {
    const [friends, setFriends] = useState([{
        __typename: 'User',
        id: 1,
        name: 'Nick',
    }])

    // 缓存应该在客户端之间持久化
    const cache = useMemo(() => {
        // 应该与您提供给真实 Apollo 客户端的缓存配置相同
        return new InMemoryCache()
    }, [])

    // 每当数据更改时,我们都需要重新创建模拟客户端,
    // 因为它不支持重置请求处理程序。
    const mockClient = useMemo(() => {
        const client = createMockClient({ cache })

        client.setRequestHandler(getFriends, () => Promise.resolve({
            data: {
                friends: friends
            }
        }))
        client.setRequestHandler(addFriend, ({ variables: { user } }) => {
            setFriends((prev) => prev.concat([user]))
            return Promise.resolve({
                data: {
                    addFriend: user
                }
            })
        })

        return client
    }, [friends])

    return mockClient
}

然后,就像我们对导航所做的那样,我们使用模拟客户端将演示封装在新的提供程序中:

+import { ApolloProvider } from '@apollo/client'

export const interactiveDemo = () => {
+   const mockClient = useDemoClient()
    return (
+       
+           
+               
+           
+       
    )
}

如果您使用模拟服务器,则可以将其 URL 注入演示应用程序的真实客户端。

视觉效果

它有效!那么我们如何让用户清楚地知道他们正在查看交互式演示呢?

我更倾向于移动优先,因此我选择在一个手机框架内渲染演示。我使用了 devices.css,因为它提供了我认为外观最佳的设备(即最小边框以最大化演示空间)。但为了简单起见,这里我们将使用一个开箱即用支持 React 的库:react-device-frameset

我们还可以使用缩放来缩小演示 UI,并将其很好地嵌套在页面的其余部分中。在 Wanna 中,当使用 和 visjs-html-nodes 绘制被邀请者图时,我必须反转并解释这种缩放,但在大多数情况下它“正常工作”。

+import { DeviceFrameset } from 'react-device-frameset'
+import 'react-device-frameset/styles/marvel-devices.min.css'

export const interactiveDemo = () => {
    const mockClient = useDemoClient()
    return (
+       
+           
+               
+                   
+               
+           
+       
    )
}

最后,添加动画效果会有所帮助,这样它就不会显得像静态图像。例如,Wanna 会在活动的输入字段中不断地幽灵输入建议。

集成

现在我们有了 interactiveDemo 组件,我们将其渲染到登录页面中,就完成了!

export const Landing = () => {
    return (
        
{/* ... */} + {/* ... */}
) }

相关专题

更多
css
css

css是层叠样式表,用来表现HTML或XML等文件样式的计算机语言,不仅可以静态地修饰网页,还可以配合各种脚本语言动态地对网页各元素进行格式化。php中文网还为大家带来html的相关下载资源、相关课程以及相关文章等内容,供大家免费下载使用。

495

2023.06.15

css居中
css居中

css居中:1、通过“margin: 0 auto; text-align: center”实现水平居中;2、通过“display:flex”实现水平居中;3、通过“display:table-cell”和“margin-left”实现居中。本专题为大家提供css居中的相关的文章、下载、课程内容,供大家免费下载体验。

258

2023.07.27

css如何插入图片
css如何插入图片

cssCSS是层叠样式表(Cascading Style Sheets)的缩写。它是一种用于描述网页或应用程序外观和样式的标记语言。CSS可以控制网页的字体、颜色、布局、大小、背景、边框等方面,使得网页的外观更加美观和易于阅读。php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

731

2023.07.28

css超出显示...
css超出显示...

在CSS中,当文本内容超出容器的宽度或高度时,可以使用省略号来表示被隐藏的文本内容。本专题为大家提供css超出显示...的相关文章,相关教程,供大家免费体验。

531

2023.08.01

css字体颜色
css字体颜色

CSS中,字体颜色可以通过属性color来设置,用于控制文本的前景色,字体颜色在网页设计中起到很重要的作用,具有以下表现作用:1、提升可读性;2、强调重点信息;3、营造氛围和美感;4、用于呈现品牌标识或与品牌形象相符的风格。

746

2023.08.10

什么是css
什么是css

CSS是层叠样式表(Cascading Style Sheets)的缩写,是一种用于描述网页(或其他基于 XML 的文档)样式与布局的标记语言,CSS的作用和意义如下:1、分离样式和内容;2、页面加载速度优化;3、实现响应式设计;4、确保整个网站的风格和样式保持统一。

592

2023.08.10

css三角形怎么写
css三角形怎么写

CSS可以通过多种方式实现三角形形状,本专题为大家提供css三角形怎么写的相关教程,大家可以免费体验。

554

2023.08.21

css设置文字颜色
css设置文字颜色

CSS(层叠样式表)可以用于设置文字颜色,这样做有以下好处和优势:1、增加网页的可视化效果;2、突出显示某些重要的信息或关键字;3、增强品牌识别度;4、提高网页的可访问性;5、引起不同的情感共鸣。

386

2023.08.22

苹果官网入口直接访问
苹果官网入口直接访问

苹果官网直接访问入口是https://www.apple.com/cn/,该页面具备0.8秒首屏渲染、HTTP/3与Brotli加速、WebP+AVIF双格式图片、免登录浏览全参数等特性。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

10

2025.12.24

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

相关下载

更多

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Sass 教程
Sass 教程

共14课时 | 0.7万人学习

Bootstrap 5教程
Bootstrap 5教程

共46课时 | 2.5万人学习

CSS教程
CSS教程

共754课时 | 16.1万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号