React UI组件库——如何快速实现antd的按需引入和自定义主题

这篇具有很好参考价值的文章主要介绍了React UI组件库——如何快速实现antd的按需引入和自定义主题。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

大家上午好呀~
今天来学习一下React的UI组件库以及antd的使用相关的知识点。
感兴趣的小伙伴可以给个三连哦~

antd react定制主题,React,javascript,前端,react.js

🔻React UI组件库

🔥流行的开源React UI组件库

  • material-ui(国外)
  • ant-design(国内蚂蚁金服)

🔥antd的基本使用

antd 是基于 Ant Design 设计体系的 React UI 组件库,主要用于研发企业级中后台产品。

安装antd组件库:

npm install antd --save
yarn add antd

默认按需引入antd组件:

import { Button, DatePicker } from 'antd';

默认按需引入icons图标:

import { WechatOutlined, SearchOutlined } from '@ant-design/icons';

默认全部引入antd组件库样式:

import 'antd/dist/antd.css';

由于全部引入antd组件库样式,会导致文件太大,影响性能问题,所以应该按需引入。

🔥antd样式按需引入

用到哪个组件的样式,就引入哪个组件的样式。参考文档

  1. 安装 react-app-rewired,customize-cra库
npm add react-app-rewired customize-cra

react-app-rewired:用于启动react脚手架(因为更新了脚手架的配置,所以不能用原来的命令启动)。

customize-cra:用于执行修改配置的命令。

  1. 修改package.json文件
"scripts": {
    "start": "react-app-rewired start",
    "build": "react-app-rewired build",
    "test": "react-app-rewired test",
    "eject": "react-scripts eject"
 }
  1. 在项目根目录创建一个 config-overrides.js 用于修改默认配置
// 配置具体的修改规则
module.exports = function override(config, env) {
  // do stuff with the webpack config...
  return config;
};
  1. 安装并使用 babel-plugin-import,它是一个用于按需加载组件代码和样式的 babel 插件。
npm add babel-plugin-import
  1. 修改 config-overrides.js 文件
// 配置具体的修改规则
const { override, fixBabelImports } = require('customize-cra');

module.exports = override(
  fixBabelImports('import', {
    libraryName: 'antd',
    libraryDirectory: 'es',
    style: 'css',
  }),
);

完成上述操作,可以移除前面在 src/App.css 里全部添加样式的代码: import 'antd/dist/antd.css'。最后重启 npm start 访问页面,antd 组件的 js 和 css 代码都会按需加载。

antd react定制主题,React,javascript,前端,react.js

🔥antd自定义主题

按照配置主题的要求,自定义主题需要用到 less 变量覆盖功能。我们可以引入 customize-cra 中提供的 less 相关的函数 addLessLoader 来帮助加载 less 样式,同时修改 config-overrides.js 文件。

  1. 安装less和less-loader:
npm add less@5 
npm add less-loader@5
// npm add less less-loader@5

less:想要修改less文件需要安装less。

less-loader:修改完之后编译less文件需要安装less-loader。

  1. 修改config-overrides.js文件:
// 配置具体的修改规则
const { override, fixBabelImports, addLessLoader } = require('customize-cra');

module.exports = override(
  fixBabelImports('import', {
    libraryName: 'antd',
    libraryDirectory: 'es',
    style: true,
  }),
  addLessLoader({
    javascriptEnabled: true,
    modifyVars: { '@primary-color': 'green' },
  }),
);

这里利用了less-loader的 modifyVars 来进行主题配置,变量和其他配置方式可以参考 配置主题 文档。

修改后重启 npm start,如果看到一个绿色的按钮就说明配置成功了。

今天的分享就到这里啦 ✨
如果对你有帮助的话,还请👉🏻关注💖点赞🤞收藏⭐评论🔥哦
不定时回访哟🌹文章来源地址https://www.toymoban.com/news/detail-784659.html

到了这里,关于React UI组件库——如何快速实现antd的按需引入和自定义主题的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包赞助服务器费用

相关文章

  • 搭建vue3项目+按需引入element-ui框架组件

    搭建vue3项目+按需引入element-ui框架组件

    场景 :使用vue create脚手架快速搭建vue的项目 前提 :需要安装node.js和cnpm以及yarn 并且cnpm需要设置为淘宝镜像,cnpm和yarn安装教程网上很多可以自行搜索 查看安装的版本(显示版本号说明安装成功) 1.cmd窗口跳到需要新建项目的文件夹下,使用vue create 2.我这里选择第三个Ma

    2024年02月16日
    浏览(18)
  • React antd如何实现<Upload>组件上传附件再次上传已清除附件缓存问题

    React antd如何实现<Upload>组件上传附件再次上传已清除附件缓存问题

    最近遇到一个React上传组件的问题,即上传附件成功后,文件展示处仍然还有之前上传附件的缓存信息,需要解决的问题是,要把上一次上传的附件缓存在上传成功或者取消后,可以进行清除 经过一顿试错,终于解决了这个问题。 showUploadList,是可选参数,即是否展示upload

    2024年02月04日
    浏览(14)
  • 第十三章 实现组件库按需引入功能

    第十三章 实现组件库按需引入功能

    组件库会包含几十甚至上百个组件,但是应用的时候往往只使用其中的一部分。这个时候如果全部引入到项目中,就会使输出产物体积变大。按需加载的支持是组件库中必须考虑的问题。 目前组件的按需引入会分成两个方法: 经典方法:组件单独分包 + 按需导入 + babel-plug

    2024年02月11日
    浏览(16)
  • React antd upload组件上传视频并实现视频预览

    记录问题:antd的upload组件文档中对于视频的上传预览没有明确的文档demo,在这里记录一下 项目需求:支持图片及视频的上传并实现预览,点击上传后不会立即请求接口上传资源,后续点击确定再上传 上代码

    2024年02月04日
    浏览(17)
  • react结合antd的Table组件实现动态单元格合并

    react结合antd的Table组件实现动态单元格合并

    首先看一下antd的Table表单组件,合并单元格,用到了rowSpan(合并行)和colSpan(合并列)  后台返回的数据 我们希望把category的值相同的,行合并成一个单元格 类似于这种  rowSpan这个属性可以指定合并行。例如说第一行,指定rowSpan为3,意思就是合并三行,则后面紧挨的两行的ro

    2024年02月12日
    浏览(11)
  • vite + vue + ts 自动按需导入 Element Plus组件,并如何解决按需引入后ElMessage与ElLoading 的问题(找不到名称“ElMessage”问题。)

    vite + vue + ts 自动按需导入 Element Plus组件,并如何解决按需引入后ElMessage与ElLoading 的问题(找不到名称“ElMessage”问题。)

    按需引入后ElMessage与ElLoading 的问题,两步优雅解决找不到名称“ElMessage”问题。不需要导入npm包,不需要下载任何东西,只要五行代码 目录 1、添加Element Plus组件库 1.2、下载 1.2、自动导入(官方推荐) 2、按需引入后ElMessage与ElLoading 的问题 2.1、解决问题 2.2、下面是分析原因

    2024年02月06日
    浏览(10)
  • element UI 按需引入

    1、npm安装【全局安装element】    2、按需引入,借助  babel-plugin-component,         2.1、首先安装 babel-plugin-component,         2.2、将.babelrc修改为:【是项目中的babel.config.js文件】         2.3、在main.js中引入需要的组件 比如:Button,Select         2.4、或者挂载在

    2024年02月16日
    浏览(7)
  • 引入element-ui步骤(按需引入和全局引入)

    两种引入方式 1)完整引入 2)按需引入 借助 babel-plugin-component,我们可以只引入需要的组件,以达到减小项目体积的目的。 a)先安装 babel-plugin-component: b)修改 babel.config.js 的内容 c)创建文件 element.js(名字自定义) d)最后在main.js中添加代码

    2024年02月16日
    浏览(15)
  • vue3 vue.config.js配置Element-plus组件和Icon图标实现按需自动引入

    vue3 vue.config.js配置Element-plus组件和Icon图标实现按需自动引入

    打包时,报警告,提示包太大会影响性能 在页面直接使用,直接使用 SVG 图标,当做一般的 svg 使用 icon使用时需要用以下两种方式方式: 如果用在el-button里面的icon属性上使用,用SVG方式无效,还是需要引入再使用(不知道有没有其他方式) 注意: 使用 :icon=\\\"Edit\\\" 则icon的大

    2024年02月06日
    浏览(48)
  • react使用antd的table组件,实现点击弹窗显示对应列的内容

    react使用antd的table组件,实现点击弹窗显示对应列的内容

    特别提醒:不能在table的columns的render里面设置弹窗组件渲染,因为这会导致弹窗显示的始终是最后一行的内容,因为这样渲染的结果是每一行都会重新渲染一遍这个弹窗并且会给传递一个content的值,渲染到最后一行的时候,就传递的是最后一行的值。这就导致你有多少行数据

    2024年02月12日
    浏览(14)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包