91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

react實現antd線上主題動態切換功能

發布時間:2020-09-01 18:15:00 來源:腳本之家 閱讀:687 作者:張小汪 欄目:web開發

demo

框架選擇: create-react-app + mobx + webpack5 + antdesign

說明

  • 由于最近公司有多個主題的共存性,所以需要實現線上主題切換的功能,所以本文主要描述的是基于create-react-app之上的主題切換。
  • CSS切換 有考慮過根據用戶選擇的主題在切換的時候選擇加載頁面css文件的區分方案,但是考慮到這種形式需要在頁面切換的時候去reload,因為htmlDOM是在css與JS的結合產物,用戶體驗不是很好。
  • Less切換 單純引入所有的less文件去做切換,這樣不能實現css的動態加載了,會增加無用css文件的加載
  • 最后通過比較及查詢,獲取到第三方插件:antd-theme-generator
  • 功能實現原則:使用 less 的 modifyVars 完成 antd 的主題變量替換。

安裝 

antd-theme-generator

缺點: 需要配合 LESS v2.7.x 使用,不兼容IE。

cnpm install antd-theme-generator -S

添加主題切換文件 color.js

根目錄下添加文件 color.js ,添加配置內容:

const path = require('path');
const { generateTheme, } = require('antd-theme-generator');

const options = {
 stylesDir: path.join(__dirname, './src/css'),
 antDir: path.join(__dirname, './node_modules/antd'),
 varFile: path.join(__dirname, './src/css/variables.less'),
 mainLessFile: path.join(__dirname, './src/css/index.less'),
 themeVariables: [ //需要動態切換的主題變量
  '@primary-color',
  '@secondary-color',
  '@text-color',
  '@text-color-secondary',
  '@heading-color',
  '@layout-body-background'
 ],
 indexFileName: 'index.html',
 outputFilePath: path.join(__dirname, './public/color.less'), //頁面引入的主題變量文件
}

generateTheme(options).then(less => {
 console.log('Theme generated successfully');
})
.catch(error => {
 console.log('Error', error);
});

CSS 文件下添加less文件

添加 variables.less 文件:

@import "~antd/lib/style/themes/default.less"; //引入antd的變量文件,實現變量的覆蓋
@primary-color: #1DA57A;
@link-color: #1DA57A;
@btn-primary-bg:#1DA57A;

HTML文件中加入全局less配置

index.html 中加入全局 less 變量配置,從而使 less 的 modifyVars 方法可以全局使用,切換主題時覆蓋 default.less 中的變量:

<!-- 使用自動生成的color.less,主要路徑與index.html文件同級 -->
<link rel="stylesheet/less" type="text/css" href="%PUBLIC_URL%/color.less" rel="external nofollow" /> 
<script>
 window.less = {
  async: false,
  env: 'production'
 };
</script>
<script type="text/javascript" src="https://cdnjs.cloudflare.com/ajax/libs/less.js/2.7.2/less.min.js"></script>

項目啟動處修改

修改項目運行配置 package.json ,項目運行的同時完成頁面color文件的配置

"scripts": {
 "start": "node color && node scripts/start.js",
 "build": "node color && node scripts/build.js",
 "test": " node color && node scripts/test.js"
},

頁面調用方法切換主題

頁面點擊主題切換配置,這樣寫的緣故是因為我配置的變量不同:

window.less.modifyVars(
 {
  '@primary-color': '#aaa',
  '@menu-dark-item-active-bg':'#aaa',
  '@link-color': '#aaa',
  '@text-color':'#aaa',
  '@btn-primary-bg': '#aaa',
 }
)
.then(() => { 
 message.success('主題切換成功')
})
.catch(error => {
 message.error(`主題切換失敗`);
 console.log(error)
});

由于之后的配置中新增的樣式需要遵循主題配置的可以選擇使用統一變量,所以變量設置的時候,可以添加 var(--PC) 的全局變量設置

總結

以上所述是小編給大家介紹的react實現antd線上主題動態切換功能,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對億速云網站的支持!
如果你覺得本文對你有幫助,歡迎轉載,煩請注明出處,謝謝!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

宿松县| 专栏| 华容县| 苏尼特左旗| 辰溪县| 绵阳市| 广饶县| 葫芦岛市| 海晏县| 平利县| 许昌县| 蓬莱市| 玉溪市| 启东市| 蒙自县| 屏东县| 陵川县| 尉氏县| 当阳市| 平果县| 若尔盖县| 黔西| 隆德县| 湟源县| 中西区| 疏附县| 格尔木市| 古蔺县| 灵川县| 涟源市| 许昌县| 常山县| 新巴尔虎左旗| 海宁市| 溧水县| 稷山县| 西吉县| 塔河县| 出国| 西林县| 乌鲁木齐县|