当前位置: 首页 > news >正文

烤漆 东莞网站建设优化网站排名公司

烤漆 东莞网站建设,优化网站排名公司,便宜的域名购买,微信怎么制作自己的公众号storybook插件addons核心插件插件APIargTypes写文档组件注释法MDX生成在线可视化UI文档上一篇: https://blog.csdn.net/tuzi007a/article/details/129194267插件addons 插件用于增强storybook的UI功能。 核心插件 storybook/addon-essentials 它几乎控制了整个s…

storybook

  • 插件addons
    • 核心插件
    • 插件API
  • argTypes
  • 写文档
    • 组件注释法
    • MDX
  • 生成在线可视化UI文档


上一篇:

https://blog.csdn.net/tuzi007a/article/details/129194267

插件addons

插件用于增强storybook的UI功能。


核心插件

@storybook/addon-essentials

它几乎控制了整个storybook的核心功能,比如

  • 生成文档页面
  • 生成控制器
  • 事件发生器
  • 窗口可视化面板
  • 背景主题
  • 面板工具条
  • 测量轮廓线

它有官方默认提供,在安装storybook时,会默认安装。

文档:

https://storybook.js.org/docs/react/essentials/introduction

控制器control

文档:

https://storybook.js.org/docs/react/essentials/controls

拓展:

https://storybook.js.org/docs/react/writing-docs/doc-block-argstable#customizing

也就是面板的控制变化的部分:

在这里插入图片描述

之前提到过,这里的显示形式和多个地方有关:

首先是组件内部的定义的数据类型,即PropTypes

如果定义为PropTypes.bool,就会显示成按钮切换形式,这是由插件内部默认设定的。

另一个影响控制器显示的是argTypes,它可以主动的改变control的显示形式,

比如当一个变量被定义为PropTypes.onOf(['a', 'b', 'c'])时,默认会显示成单选按钮的形式,

如果在argTypes中做如下修改:

argTypes: {xxx: { control: 'select' }
}

就会让控制器显示成下拉选择框的形式。

还有Parameters配置项,也会影响控制器,比如默认生成的preview.js中就有:

export const parameters = {actions: { argTypesRegex: "^on[A-Z].*" },controls: {matchers: {color: /(background|color)$/i,date: /Date$/,},},
}

代码的含义在之前说过,不赘述。


插件API

通过学习插件api,可以自己写addons插件。

一个自定义插件的使用,分以下步骤:

  • 写插件
  • main.js中注册
  • 在使用该插件的文件中引入并使用

写插件:

https://storybook.js.org/docs/react/addons/writing-addons

插件API:

https://storybook.js.org/docs/react/addons/addons-api

argTypes

前面提到过,他可以主动改变控制器的显示形式。

可以仔细阅读argTypes的一些结构式的写法:

https://storybook.js.org/docs/react/essentials/controls#annotation

写文档

回到最初的目标,我们是要生成可视化文档的,这个文档要怎么写,才更符合预期呢?

目前来看,有两种方式:

  • 组件注释法。即直接在组件内写注释说明,注释/* xxx */里的内容,会被当成md内容进行加载。
  • MDX。写一个.stories.mdx文件,会生成一个可视化文档

组件注释法

我们还以Button.jsx组件为例。

看下代码:

import React from 'react';
import PropTypes from 'prop-types';
import './index.less';/*** Primary UI component for user interaction* # hello button !* `这里是Button组件`*/
const Button = ({ primary, backgroundColor, size, label, ...props }) => {const mode = primary ? 'storybook-button--primary' : 'storybook-button--secondary';return (<buttontype="button"className={['storybook-button', `storybook-button--${size}`, mode].join(' ')}style={backgroundColor && { backgroundColor }}{...props}>{label}</button>);
};export default Button;Button.propTypes = {/*** Is this the principal call to action on the page?*/primary: PropTypes.bool,/*** What background color to use*/backgroundColor: PropTypes.string,/*** How large should the button be?*/size: PropTypes.oneOf(['small', 'medium', 'large']),/*** Button contents*/label: PropTypes.string.isRequired,/*** Optional click handler*/onClick: PropTypes.func,
};Button.defaultProps = {backgroundColor: null,primary: false,size: 'medium',onClick: undefined,
};

再展示下它的文档:
在这里插入图片描述

可以看出,由/**/包含的注释内容,将会被当作md文档加载进来,并且注释内的内容会支持部分md语法。

而且,Button.propTypes中的注释,会被直接当作控制面板中描述(Description)参数的文案。

这样,就形成了一份简单明了的可视化文档。这种方式需要写.stories.jsx文件,两者配合。

同时,这也提醒开发者,不要在组件里随便写/**/注释,因为这些注释会被显露给用户。


MDX

第二种方式,写.stories.mdx文档。此时就可以不写.stories.jsx文件了。

MDX文档是md + jsx语法,还可以写样式代码。

文档:

https://storybook.js.org/docs/react/writing-docs/mdx

.stories.jsx文件相比,.stories.mdx的优势在于,它生成的可视化文档可以增加更多的描述内,

还可以增加样式,并添加导航。

基本步骤:

  • @storybook/addon-docs插件中引入需要的组件,如Meta , Story, Canvas, ArgsTable
  • 引入要使用的组件,比如Button
  • 导出Template模板
  • 写story
  • 引入控件面板

写一个最简单的mdx文档:

import { Meta, Story } from '@storybook/addon-docs';
import { Button } from '../src';<Meta title="MDX/Button" component={Button} />export const Template = (args) => <Button {...args} /># 写一个primary story<Storyname="primary"args={{primary: true,label: 'click me'}}
>{Template.bind({})}
</Story>

生成的文档:
在这里插入图片描述
这是一个最基础的文档,在Docs中没有任何交互。

要想在Docs中展示控制面板,需要引入ArgsTable,并用它的of语法解析Button组件。

import { ArgsTable, Meta, Story } from '@storybook/addon-docs';
import { Button } from '../src';<Meta title="MDX/Button" component={Button} />export const Template = (args) => <Button {...args} /># 写一个primary story<Storyname="primary"args={{primary: true,label: 'click me'}}
>{Template.bind({})}
</Story><ArgsTable of={Button} />

再看下现在的文档,出现了下面的控制面板:
在这里插入图片描述
为了让文档看起来更好看,我们给他加一句话,并写入样式,来展示一下:
在这里插入图片描述
代码:

import { ArgsTable, Meta, Story } from '@storybook/addon-docs';
import { Button } from '../src';<Meta title="MDX/Button" component={Button} />export const Template = (args) => <Button {...args} /># 写一个primary story<style>{`.intro {--mediumdark: '#999999';font-size: 15px;color: #999;font-weight: 600;letter-spacing: 2px;line-height: 24px;margin-top: 10px;margin-buttom: 10px;}`}
</style><p className="intro">以Button组件为例:</p><Storyname="primary"args={{primary: true,label: 'click me'}}
>{Template.bind({})}
</Story><ArgsTable of={Button} />

生成在线可视化UI文档

一切准备就绪,怎么把文档发到服务器上,让别的用户也能看到呢?

storybook有开发环境的打包指令,

npm run build-storybook

然后它会把打包后的文件放在storybook-static文件夹下。

这是一部分打包结果:
在这里插入图片描述

看到index.html文件,你是否一下子就明白了。

有html文件,发布到服务器上,就很简单了。

我们先把打包后的文件上传到gitee。(国内的gitee,打开网站会更快,部署也更快)

在这里插入图片描述

在项目页面,点击服务,点击Gitee Pages
在这里插入图片描述

在这个页面填写分支和目录,发布或更新即可。
在这里插入图片描述
发布成功后,当前页面会出现一个链接:
在这里插入图片描述

这个链接就是你写的可视化UI文档了。
在这里插入图片描述


http://www.tj-hxxt.cn/news/102060.html

相关文章:

  • 签到 做任务赚钱的网站百度推广竞价技巧
  • 网站如何做自适应公关公司排行榜
  • 网格系统网站营销管理系统
  • 网站建设专家论证会网站浏览器
  • 阳泉网站建设哪家便宜seo排名优化关键词
  • 网络系统开发佛山百度网站排名优化
  • 天津网上商城网站建设1小时快速搭建网站
  • 政务网站建设的三大核心功能是什么渠道推广
  • lindberg定制网站爱站网关键词挖掘
  • 建网站做淘宝客赚钱吗百度世界排名
  • 平安保险网站官方网址网站排名查询工具有哪些
  • 更改wordpress链接数据库工具seo
  • sql网站发布流程百度指数是什么
  • 中国建设社银行招聘网站百度搜索排名优化
  • 网站首页图怎么做交换链接营销的典型案例
  • 佛山市门户网站建设公司上海怎么做seo推广
  • 做商城网站费用百度关键词竞价
  • 邢台网站建设 冀icp备日照网络推广公司
  • 做海报有什么好的网站推荐清理大师
  • 建设网站如何加入搜索百度app下载链接
  • 二手车网站源码下载怎么在百度做网站推广
  • 网站开发宣传图片google谷歌搜索引擎入口
  • 做网站需要哪种工程师sem竞价托管多少钱
  • 写作网站招聘企业文化培训
  • 做机械加工外贸网站哪家好百度指数查询平台
  • 佛山网站优化排名推广建网站的公司排名
  • 查钓鱼网站seo网络排名优化方法
  • 建设部网站办事大厅栏目数字经济发展情况报告
  • 网站制作 武汉广州市新闻最新消息
  • 网站后台管理图片网站seo排名优化工具