成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專(zhuān)欄INFORMATION COLUMN

React項(xiàng)目 - 幾種CSS實(shí)踐

princekin / 1313人閱讀

摘要:一切樣式都是全局,產(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 
A0
B0
; } /* table.css */ .table {} .row {} .cell {}

缺點(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

相關(guān)文章

  • CSS Modules實(shí)踐

    摘要:能最大化地結(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...

    hankkin 評(píng)論0 收藏0
  • 3月份前端資源分享

    摘要:面試如何防騙一份優(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...

    nanchen2251 評(píng)論0 收藏0
  • 一名【合格】前端工程師的自檢清單

    摘要:在他的重學(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)成為研...

    羅志環(huán) 評(píng)論0 收藏0
  • 一名【合格】前端工程師的自檢清單

    摘要:在他的重學(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ā)體系...

    isaced 評(píng)論0 收藏0
  • Drag&Drop 拖放API簡(jiǎn)介以及在React中的實(shí)踐

    摘要:如其他屬性及方法,詳細(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、通...

    lcodecorex 評(píng)論0 收藏0

發(fā)表評(píng)論

0條評(píng)論

最新活動(dòng)
閱讀需要支付1元查看
<