博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
create-react-app同时对多个框架(antd+antd-mobile)做按需加载的方法
阅读量:6244 次
发布时间:2019-06-22

本文共 2259 字,大约阅读时间需要 7 分钟。

在React项目开发中,经常需要引用一些实用的第三方框架。在使用一些比较庞大的第三方框架时,框架内的各种资源文件数量巨大,这时,如果我们在每次使用框架时,都将框架内所有资源都全部加载的话,这将使得页面的性能大大降低。这时,我们就需要对这些庞大的第三方框架做按需加载了。

首先介绍下对单个框架做按需加载的方法

其实在使用create-react-app脚手架的情况下,对单个框架做按需加载的方法,网上的相关文章已经很多了,我这里只简单的介绍下。常用的方法就是通过babel-plugin-import来实现按需加载,并通过react-app-rewired来重写项目配置文件,将babel-plugin-import写入配置。

1、安装

cnpm install babel-plugin-import --devcnpm install react-app-rewired --dev

2、修改package.json

"scripts": {-   "start": "react-scripts start",+   "start": "react-app-rewired start",-   "build": "react-scripts build",+   "build": "react-app-rewired build",-   "test": "react-scripts test",+   "test": "react-app-rewired test",}

3、在项目的根目录下创建一个 config-overrides.js 用于修改默认配置

const {injectBabelPlugin} = require('react-app-rewired');const rewireLess = require('react-app-rewire-less');const path = require('path')module.exports = function override(config, env) {    config = injectBabelPlugin(        ['import',            {                libraryName: 'antd',                libraryDirectory: 'es',                style: true            }        ],        config    );    config = rewireLess.withLoaderOptions({        modifyVars: {"@primary-color": "#4197FC"},        javascriptEnabled: true,    })(config, env);    return config;};

这样就完成了对antd的按需加载

那么对多个框架做按需加载应该怎么做呢?

对多个框架做按需加载的方法

这里拿antd和antd-mobile两个框架来举例子

首先还是要按照上面的步骤安装babel-plugin-importreact-app-rewired,并修改默认配置,区别只是在最后一步上。在调用babel-plugin-import的injectBabelPlugin方法时,需要调用两次,并注明相对应的框架名。具体代码如下:

const {injectBabelPlugin} = require('react-app-rewired');const rewireLess = require('react-app-rewire-less');const path = require('path')module.exports = function override(config, env) {    config = injectBabelPlugin(        ['import',            {                libraryName: 'antd',                libraryDirectory: 'es',                style: true            }, 'ant'        ],        config    );    config = injectBabelPlugin(        ['import',            {                libraryName: "antd-mobile",                libraryDirectory: 'lib',                style: true            }, 'ant-mobile'        ],        config    );    config = rewireLess.withLoaderOptions({        modifyVars: {"@primary-color": "#4197FC"},        javascriptEnabled: true,    })(config, env);    return config;};

转载地址:http://gvpia.baihongyu.com/

你可能感兴趣的文章
开源SIP服务器加密软件NethidPro升级
查看>>
Apache Pulsar中的地域复制,第1篇:概念和功能
查看>>
南京大学周志华教授当选欧洲科学院外籍院士
查看>>
计算机网络与Internet应用
查看>>
oracle在线迁移同步数据,数据库报错
查看>>
linux性能剖析工具
查看>>
flutter中的异步
查看>>
计算机高手也不能编出俄罗斯方块——计算机达人成长之路(16)
查看>>
# 2017-2018-1 20155224 《信息安全系统设计基础》第七周学习总结
查看>>
scikit-learn预处理实例之一:使用FunctionTransformer选择列
查看>>
Oracle11G 卸载步骤
查看>>
Mars说光场(3)— 光场采集
查看>>
中小企业客户营收增长将成微博2016年主推动力
查看>>
第一个掘金文章
查看>>
我的友情链接
查看>>
微信Windows版无法备份聊天记录
查看>>
Github上传代码菜鸟超详细教程
查看>>
资金项目性能优化
查看>>
Java将图片处理成背景透明的圆形图片
查看>>
知道IP地址怎么查看mac地址
查看>>