React樣式?jīng)_突解決問題的方法
前言:
1、React最終編譯打包后都在一個html頁面中,如果在兩個組件中取一樣類名分別引用在自身,那么后者會覆蓋前者。
2、默認情況下,只要導(dǎo)入了組件,不管組件有沒有顯示在頁面中,組件的樣式就會生效。
解決方案:
- 手動處理 (起不同的類名,但是項目一大就會導(dǎo)致類名很亂,不利于團隊協(xié)作)
CSS IN JS: 以js的方式來處理css(推薦)- css不是一門編程語言,css沒有所有的局部作用域全局作用域這樣的區(qū)分。。。css只有全局作用域
CSS IN JS
一、概念
CSS IN JS:是使用 JavaScript 編寫 CSS 的統(tǒng)稱,用來解決 CSS 樣式?jīng)_突、覆蓋等問題
CSS IN JS 的具體實現(xiàn)有 50 多種,比如:React常用(CSS Modules、styled-components)、 Vue常用(<style scoped> 、css modules)等
推薦使用:CSS Modules (React腳手架已集成,可直接使用)
二、CSS Modules
- CSS Modules 通過對 CSS 類名重命名,保證每個類名的唯一性,從而避免樣式?jīng)_突的問題
- 換句話說:所有類名都具有“局部作用域”,只在當前組件內(nèi)部生效
- 在 React 腳手架中:文件名、類名、hash(隨機)三部分,只需要指定類名即可 BEM
xxxx.module.css
1、自動生成的類名,我們只需要提供 classname 即可
[filename]_[classname]_[hash]
2、
類名:.error {}.red{}
實際生成的類名為:.NavHeader_error__ax7yz.NavHead_red_abcdc(相同命名的類名,經(jīng)過module處理以后,會生成不同的實際類名,特殊標識)
三、在項目中使用css Modules
創(chuàng)建名為 [name].module.css 的樣式文件(React腳手架中的約定,與普通 CSS 作區(qū)分)
組件中導(dǎo)入該樣式文件(注意語法)
通過 styles 對象訪問對象中的樣式名來設(shè)置樣式

css module的注意點:
- 類名最好使用駝峰命名,因為最終類名會生成
styles的一個屬性.tabBar {}=>styles.tabBar - 如果沒有使用駝峰命名,對于不合法的命名,需要使用[]語法
.tab-bar {}=>styles['tab-bar'] - 如果是全局的類名,應(yīng)該使用
:global(.類名)的方式,不然會把全局類名給修改掉
:global(.icon-map) { }這樣css modules就不會修改掉類名了
四、css module配合sass
- css moudule也可以配合sass來使用,創(chuàng)建名為
[name].module.scss - 使用css modules解決Login組件樣式?jīng)_突問題
- 如果sass文件中使用到了鏈接,需要使用絕對路徑
~

五、module.scss 使用步驟:


六、總結(jié)
React樣式?jīng)_突總結(jié):
sass和CSS Moudles 的搭配使用,解決了React中樣式?jīng)_突的問題。
我們?nèi)匀豢梢栽诓煌M件中使用相同類名,但我們需要知道,名字相同的類名在Moudle的作用下,實際類名并不相同,以此確保了,樣式只在當前組件內(nèi)生效。
React采取的是組件化編程,組件和組件對應(yīng)的樣式會放在同一個組件文件夾下。
但我們?nèi)匀恍枰溃涸谧詈缶幾g打包之后,所有組件的解構(gòu)和樣式,都會打包在同一個html頁面中。
到此這篇關(guān)于React樣式?jīng)_突解決問題的方法 的文章就介紹到這了,更多相關(guān)React樣式?jīng)_突內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
react-router 路由切換動畫的實現(xiàn)示例
這篇文章主要介紹了react-router 路由切換動畫的實現(xiàn)示例,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2018-12-12
用react-redux實現(xiàn)react組件之間數(shù)據(jù)共享的方法
這篇文章主要介紹了用react-redux實現(xiàn)react組件之間數(shù)據(jù)共享的方法,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2018-06-06
React競態(tài)條件Race Condition實例詳解
這篇文章主要為大家介紹了React競態(tài)條件Race Condition實例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2022-11-11
React Native實現(xiàn)進度條彈框的示例代碼
本篇文章主要介紹了React Native實現(xiàn)進度條彈框的示例代碼,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-07-07

