React 样式

React.js入门基础与案例开发 by ParryKK in imooc.com 学习笔记

内联样式

  • render 里定义

    ./src/js/header.js

    import React from 'react';
    export default class ComponentHeader extends React.Component {
      render() {
        const styleComponentHeader = {
          header: {
            backgroundColor: "#333333",
            color: "#FFFFFF",
            "padding-top": "15px",       // 原始css属性需要用引号
            paddingBottom: "15px"
          },
          //还可以定义其他的样式
        };
        return (
          <header style={styleComponentHeader.header}>
          <h1>这里是头部</h1>
          </header>
        )
      }
    }
    
  • 引用外部css文件

    ./src/css/style.css

    .smallFontSize h1{
      font-size: 12px;
    }
    
    .smallFontSizeFooter h1{
      font-size: 14px;
    }
    

    ./src/js/header.js, class 改成 className

    import React from 'react';
    export default class ComponentHeader extends React.Component {
      render() {
        return (
    
          <header className="smallFontSize">
            <h1>这里是头部</h1>
          </header>
    
        )
      }
    }
    

    需要在 ./index.html 里引用 css 文件

    <!-- index.html -->
    <head>
      <link rel="stylesheet" href="./src/css/style.css" />
    </head>
    <div id="example">123</div>
    <script src="./src/bundle.js"></script>
    
  • 动画、伪类(hover)不能用

内联样式中的表达式

  • state 引起样式的即时变化

    ./src/js/header.js

    import React from 'react';
    export default class ComponentHeader extends React.Component {
      constructor(){
        super();
        this.state ={
          miniHeader: false //默认加载的时候还是高(不是 mini)的头部
        };
      };
    
      switchHeader(){
        this.setState({
          miniHeader: !this.state.miniHeader
        });
      };
    
      render() {
        const styleComponentHeader = {
          header: {
            backgroundColor: "#333333",
            color: "#FFFFFF",
    
          "padding-top": (this.state.miniHeader) ? "3px" : "15px",
          paddingBottom: (this.state.miniHeader) ? "3px" : "15px"
    
        },
        //还可以定义其他的样式
    };
    return (
      <header style={styleComponentHeader.header} className="smallFontSize" onClick={this.switchHeader.bind(this)}>
      <h1>这里是头部</h1>
      </header>
      )
    }
    }
    

CSS 模块化

  • 非模块化缺点

    • 全局污染
    • 命名混乱
    • 依赖管理不彻底
    • 无法共享变量
    • 代码压缩不彻底


  • CSS 模块化插件 (npm 安装)

    • babel-plugin-react-html-attrs - 不需要将 class 改成 className, 解决直接从其它项目copy css 样式使用

    • style-loader

    • css-loader

      • webpack.config.js 配置 css-loader

        ./webpack.config.js

        var debug = process.env.NODE_ENV !== "production";
        var webpack = require('webpack');
        var path = require('path');
        
        module.exports = {
          context: path.join(__dirname),
          devtool: debug ? "inline-sourcemap" : null,
          entry: "./src/js/index.js",
          module: {
            loaders: [
              {
                test: /\.js?$/,
                exclude: /(node_modules)/,
                loader: 'babel-loader',
                query: {
                  presets: ['react', 'es2015'],
                  plugins: ['react-html-attrs'], //添加组件的插件配置
                }
              },
        
              //下面是添加的 css 的 loader,也即是 css 模块化的配置方法,大家可以拷贝过去直接使用
              {
                test: /\.css$/,
                loader: 'style!css-loader?modules&importLoaders=1&localIdentName=[name]__[local]___[hash:base64:5]'
              },
        
            ]
          },
          output: {
            path: __dirname,
            filename: "./src/bundle.js"
          },
          plugins: debug ? [] : [
            new webpack.optimize.DedupePlugin(),
            new webpack.optimize.OccurenceOrderPlugin(),
            new webpack.optimize.UglifyJsPlugin({ mangle: false, sourcemap: false }),
          ],
        };
        
  • CSS 模块导入

    ./src/css/footer.css

    .miniFooter{
      background-color: #333333;
      color: #ffffff;
      padding-left: 20px;
      padding-top: 3px;
      padding-bottom: 3px;
    }
    
    .miniFooter h1{
      font-size: 15px;
    }
    

    ./src/js/footer.js

    import React from 'react';
    
    // css样式导入
    var footerCss  =  require("../../css/footer.css");
    
    export default class ComponentFooter extends React.Component{
      render(){
        console.log(footerCss);
        return (
    
          // css样式使用
          <footer class={footerCss.miniFooter}>
    
            <h1>这里是页脚,一般放置版权的一些信息。</h1>
          </footer>
        )
      }
    }
    
  • CSS 模版的全局和本地样式

    • 本地样式,经过 CSS 模版导入使用

      ./src/css/footer.css

      .miniFooter{
        background-color: #333333;
        color: #ffffff;
        padding-left: 20px;
        padding-top: 3px;
        padding-bottom: 3px;
      }
      
      .miniFooter h1{
        font-size: 15px;
      }
      

      ./src/css/footer.css

      :local(.miniFooter){
        background-color: #333333;
        color: #ffffff;
        padding-left: 20px;
        padding-top: 3px;
        padding-bottom: 3px;
      }
      
      :local(.miniFooter) h1{
        font-size: 15px;
      }
      
-   全局样式

    > `./src/css/footer.css`

    ```CSS
    :global(.miniFooter){
      background-color: #333333;
      color: #ffffff;
      padding-left: 20px;
      padding-top: 3px;
      padding-bottom: 3px;
    }

    :global(.miniFooter) h1{
      font-size: 15px;
    }
    ```

CSS 模块化的有点

  • 所有样式都是 local 的, 解决了命名冲突和全局污染问题

  • class 名生成规则配置灵活, 可以压缩 class

  • 只需引用组件的 JS 就能搞定组件的所有的 JSCSS

  • 依然是 CSS, 几乎令学习成本

JSX 样式于 CSS 样式的互换

CSS to React: https://staxmanade.com/CssToReact/

CSS

.miniFooter{
  background-color: #333333;
  color: #ffffff;
  padding-left: 20px;
  padding-top: 3px;
  padding-bottom: 3px;
}

.miniFooter h1{
  font-size: 15px;
}

React JSX

{
  "miniFooter": {
    "backgroundColor": "#333333",
    "color": "#ffffff",
    "paddingLeft": "20px",
    "paddingTop": "3px",
    "paddingBottom": "3px"
  },
  "miniFooter_h1": {
    "fontSize": "15px"
  }
}

React 样式框架

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 204,293评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,604评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,958评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,729评论 1 277
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,719评论 5 366
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,630评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,000评论 3 397
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,665评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,909评论 1 299
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,646评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,726评论 1 330
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,400评论 4 321
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,986评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,959评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,197评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 44,996评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,481评论 2 342

推荐阅读更多精彩内容

  • 1 Webpack 1.1 概念简介 1.1.1 WebPack是什么 1、一个打包工具 2、一个模块加载工具 3...
    Kevin_Junbaozi阅读 6,635评论 0 16
  • 很久很久以前,就有人用CSS来时给HTML内容添加样式。CSS可以最大限度的分离样式和内容,选择器也可以很方便的给...
    uncle_charlie阅读 10,570评论 0 1
  • 在正常观看影片之后,大概了解了整个故事脉络和人物设定。如果我们想更细致的了解导演的意图。我们就要进行拉片子,其实就...
    米虫电影阅读 1,797评论 0 7
  • 前一天晚上,定好闹钟,7点半,本想“今晚睡的晚了,晚起是可以的”。今早,天蒙蒙亮,醒来,4点半,冥想一个小时。起...
    恨水忆昔阅读 188评论 0 2