摘要:一切樣式都是全局,產(chǎn)生的各種命名的痛苦,等命名規(guī)則能解決一部分問(wèn)題,但當(dāng)你使用三方插件時(shí)卻無(wú)法避免命名沖突。這一解決法的優(yōu)雅在于,全局的可以正常使用,只有帶后綴的才會(huì)被化使用的模板字符串,在文件里寫(xiě)純粹的。
前言
團(tuán)隊(duì)在使用react時(shí),不斷探索,使用了很多不同的css實(shí)現(xiàn)方式,此篇blog總結(jié)了,react項(xiàng)目中常見(jiàn)的幾種css解決方案:inline-style/radium/style-component,只列舉了團(tuán)隊(duì)項(xiàng)目中用過(guò)的一下實(shí)現(xiàn)方式,還有其他的不過(guò)多展開(kāi)
css的不足
樣式與狀態(tài)相關(guān)的情況越來(lái)越多,需要?jiǎng)討B(tài)、能直接訪(fǎng)問(wèn)組件state的css。
一切樣式都是全局,產(chǎn)生的各種命名的痛苦,BEM等命名規(guī)則能解決一部分問(wèn)題,但當(dāng)你使用三方插件時(shí)卻無(wú)法避免命名沖突。
Vue怎么解決
scoped 屬性
動(dòng)態(tài)css的語(yǔ)法 v-bind class style
react中使用css的標(biāo)準(zhǔn)
是否解決了React開(kāi)發(fā)的痛點(diǎn):局部css,動(dòng)態(tài)css?
是否支持所有css甚至是sass用法?偽類(lèi),嵌套,動(dòng)畫(huà),媒體查詢(xún)?
是否兼容你需要使用的第三方UI庫(kù)?
是否能和純css,或者是其他css框架很好共存,以備遇到特殊情況可以有方案B?
性能?大小?
react 原生css
inline style
const textStyles = { color: "white", backgroundColor: this.state.bgColor };inline style
缺點(diǎn):
發(fā)明了一套新的 css-in-js 語(yǔ)法,使用駝峰化名稱(chēng)等一些規(guī)則 不支持所有的 css,例如 media queries, browser states (:hover, :focus, :active) and modifiers (no more .btn-primary!). inline 寫(xiě)法如果直接同行寫(xiě)影響代碼閱讀,不清晰優(yōu)雅
Radium
Features:
Conceptually simple extension of normal inline styles 原生css擴(kuò)展,改良版
Browser state styles to support :hover, :focus, and :active 支持瀏覽器樣式
Media queries 支持媒體查詢(xún)
Automatic vendor prefixing 自動(dòng)組件前綴 scope
Keyframes animation helper 寫(xiě)動(dòng)畫(huà)更方便,封裝Keyframes
ES6 class and createClass support 支持react類(lèi)和createClass的寫(xiě)法
簡(jiǎn)單使用:
import Radium from "radium"; import React from "react"; import color from "color"; class Button extends React.Component { static propTypes = { kind: PropTypes.oneOf(["primary", "warning"]).isRequired }; render() { return ( ); } } // 使用了HOC的方式注入樣式 // Radium"s primary job is to apply interactive or media query styles, but even // if you are not using any special styles, the higher order component will still: // Merge arrays of styles passed as the style attribute // Automatically vendor prefix the style object // Radium(config)(component) 還可以傳入一些配置 Button = Radium(Button); var styles = { base: { color: "#fff", ":hover": { background: color("#0074d9").lighten(0.2).hexString() } }, primary: { background: "#0074D9" }, warning: { background: "#FF4136" } };
keyframes使用
class Spinner extends React.Component { render () { return (); } } Spinner = Radium(Spinner); var pulseKeyframes = Radium.keyframes({ "0%": {width: "10%"}, "50%": {width: "50%"}, "100%": {width: "10%"}, }, "pulse"); var styles = { inner: { // Use a placeholder animation name in `animation` animation: "x 3s ease 0s infinite", // Assign the result of `keyframes` to `animationName` animationName: pulseKeyframes, background: "blue", height: "4px", margin: "0 auto", } };
Css Modules
適用于所有使用 webpack 等打包工具的開(kāi)發(fā)環(huán)境
{ loader: "css-loader", options: { importLoaders: 1, modules: true, localIdentName: "[name]__[local]___[hash:base64:5]" // 為了生成類(lèi)名不是純隨機(jī) }, }, import styles from "./table.css"; render () { return; } /* table.css */ .table {} .row {} .cell {}A0B0
缺點(diǎn):
class名必須是駝峰形式,否則不能正常在js里使用 styles.table 來(lái)引用 由于css模塊化是默認(rèn),當(dāng)你希望使用正常的全局css時(shí),需要通過(guò):local 和 :global 切換,不方便 所有的 className 都必須使用 {style.className} 的形式 寫(xiě)在外部樣式文件中,無(wú)法處理動(dòng)態(tài)css
優(yōu)化:
babel-plugin-react-css-modules 可以照常寫(xiě) "table-size" 之類(lèi)帶橫杠的類(lèi)名 正常書(shū)寫(xiě)字符串類(lèi)名,不用加style前綴
// .bablerc { "plugins": [ ["react-css-modules", { // options }] ] }
缺點(diǎn):
不過(guò)使用 styleName 遇到三方UI庫(kù)該怎么辦呢
補(bǔ)充:
create-react-app v2 直接使用css-moudues和sass
使用方法為一律將css文件命名為 XXX.modules.css, 以上例,即為 table.modules.css, 即可使用。這一解決法的優(yōu)雅在于,全局的css可以正常使用,只有帶.modules.css后綴的才會(huì)被modules化
styled-components
使用 ES6 的模板字符串,在js文件里寫(xiě)純粹的css。
補(bǔ)充sass常用語(yǔ)法
變量:以$開(kāi)頭/變量需要在字符串之中,在#{}之中
計(jì)算: 屬性可以使用算式
嵌套: &引用父元素
繼承: @extend
重用: @mixin命令,定義一個(gè)代碼塊(可以傳參數(shù))/@include命令,調(diào)用這個(gè)mixin
引入文件: @import
// 變量 $blue : #1875e7; $side : left; div { color : $blue; } .rounded { border-#{$side}-radius: 5px; } // 計(jì)算 body { margin: (14px/2); top: 50px + 100px; right: $var * 10%; } // 嵌套 a { &:hover { color: #ffb3ff; } } // 繼承 .class1 { border: 1px solid #ffffd; } .class2 { @extend .class1; font-size:120%; } // 重用 @mixin left($value: 10px) { float: left; margin-right: $value; } div { @include left(20px); } //引入外部文件 @import "path/filename.scss"
文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請(qǐng)注明本文地址:http://systransis.cn/yun/114185.html
摘要:能最大化地結(jié)合現(xiàn)有生態(tài)預(yù)處理器后處理器等和模塊化能力,幾乎零學(xué)習(xí)成本。編碼相關(guān)的所有樣式上例中打印的結(jié)果是注意到是按照自動(dòng)生成的名。實(shí)踐手動(dòng)引用渲染結(jié)果使用可以實(shí)現(xiàn)使用屬性自動(dòng)加載模塊。 文章同步于Github Pines-Cheng/blog 隨著前端這幾年的風(fēng)生水起,CSS作為前端的三劍客之一,各種技術(shù)方案也是層出不窮。從CSS prepocessor(SASS、LESS、Styl...
摘要:面試如何防騙一份優(yōu)秀的前端開(kāi)發(fā)工程師簡(jiǎn)歷是怎么樣的作為,有哪些一般人我都告訴他,但是他都不聽(tīng)的忠告如何面試前端工程師 更多資源請(qǐng)Star:https://github.com/maidishike... 文章轉(zhuǎn)自:https://github.com/jsfront/mo... 3月份前端資源分享 1. Javascript 使用judge.js做信息判斷 javascript...
摘要:在他的重學(xué)前端課程中提到到現(xiàn)在為止,前端工程師已經(jīng)成為研發(fā)體系中的重要崗位之一。大部分前端工程師的知識(shí),其實(shí)都是來(lái)自于實(shí)踐和工作中零散的學(xué)習(xí)。一基礎(chǔ)前端工程師吃飯的家伙,深度廣度一樣都不能差。 開(kāi)篇 前端開(kāi)發(fā)是一個(gè)非常特殊的行業(yè),它的歷史實(shí)際上不是很長(zhǎng),但是知識(shí)之繁雜,技術(shù)迭代速度之快是其他技術(shù)所不能比擬的。 winter在他的《重學(xué)前端》課程中提到: 到現(xiàn)在為止,前端工程師已經(jīng)成為研...
摘要:在他的重學(xué)前端課程中提到到現(xiàn)在為止,前端工程師已經(jīng)成為研發(fā)體系中的重要崗位之一。大部分前端工程師的知識(shí),其實(shí)都是來(lái)自于實(shí)踐和工作中零散的學(xué)習(xí)。一基礎(chǔ)前端工程師吃飯的家伙,深度廣度一樣都不能差。開(kāi)篇 前端開(kāi)發(fā)是一個(gè)非常特殊的行業(yè),它的歷史實(shí)際上不是很長(zhǎng),但是知識(shí)之繁雜,技術(shù)迭代速度之快是其他技術(shù)所不能比擬的。 winter在他的《重學(xué)前端》課程中提到: 到現(xiàn)在為止,前端工程師已經(jīng)成為研發(fā)體系...
摘要:如其他屬性及方法,詳細(xì)可以查看跨終端能力跨終端能力是最大的特點(diǎn)。在指定區(qū)域的事件中,通過(guò)對(duì)象的屬性,即可獲得文件列表信息,如打印文件名在中實(shí)踐在項(xiàng)目中使用,依然遵循數(shù)據(jù)驅(qū)動(dòng)的原則,即事件數(shù)據(jù)更新。同時(shí),在事件中執(zhí)行判斷。最近有個(gè)需求,需要產(chǎn)品導(dǎo)航欄支持拖放。 雖然開(kāi)源社區(qū)已有不少成熟的拖放庫(kù),但考慮到代碼可控性和可定制性,還是自己寫(xiě)吧。 選型 關(guān)于選型,前端實(shí)現(xiàn)拖放功能,無(wú)外乎幾種: 1、通...
閱讀 2086·2021-09-29 09:35
閱讀 691·2021-09-08 09:36
閱讀 3399·2021-09-03 10:30
閱讀 2118·2019-08-30 14:21
閱讀 2915·2019-08-30 11:18
閱讀 3319·2019-08-29 17:31
閱讀 3146·2019-08-29 17:29
閱讀 1314·2019-08-29 17:13