浅谈CSS的现世(未完待更)

现在JavaScript的发展速度很快,有了很多的功能,被用到了更多的领域。JS社区的人已经疯了,提出了JoT的概念,即“JavaScript of Things”,万物皆用JavaScript,是不是很熟悉?对的对的,最近一直大热的物联网(Internet of Things,简称IoT)便是他们的下一个发展的目标,而这次主角只有一个弱类型语言——JavaScript,企图统一世界。作为JS的好姬友,HTML也升级成HTML5而成为开发者的新宠儿。再来看看同是三剑客之一的CSS,虽然CSS3有了很多新特性,但是由于CSS本身的功能局限性,以及模块化困难而造成的诸多不便,使很多开发者走向了极端,即舍弃CSS,改用JS和JSON来编写样式(CSS:你咋不上天!),于是诞生了诸如 reactcssRadiumjsxstylereact-style 之类的模块化样式。此外,还有一种主流的CSS模块化解决方案是,将CSS与JS结合,用JS来管理CSS模块,比如CSS Modules。这些模块化的样式为管理样式带来了便利,同时也为CSS注入了新活力。

react.js中的CSS模块化实现方法


今天我们先来谈谈react.js中自带的CSS模块化语法(注意这里的CSS模块化写法是react内有的,和reactCSS与react-style这些可维护模块不一样),这是一个完全使用JavaScript来定义样式的方法。与曾经的链入外部样式表不同,react.js更提倡inline style,即内嵌式样式表。

* BEFORE!*


首先,我们得入门 react.js,得引入react三件套:

<!-- react -->
<script type="text/javascript" src="js/browser.min.js" ></script>
<script type="text/javascript" src="js/react.min.js" ></script>
<script type="text/javascript" src="js/react-dom.min.js" ></script>

一定要注意** 顺序**!

* START!*


  • ** 第一种**,也是最容易理解的一种写法,即普通地使用class选择器来写CSS样式:
/*common.css*/
.forExample {
    background-color: skyblue;
    color: white;
}
/*common.js*/
var ForExample = React.createClass({
    render: function() {
        return (
            <div className="forExample">
                Just for Fun!
            </div>
        );
    }
});
ReactDOM.render(
    <ForExample />,
    document.getElementById("select1")
);
  • ** 第二种**,也是最直接的写法,直接在虚拟DOM上写入内联样式,即inline style:
var ForExample = React.createClass({
    render: function() {
        return (
            <div style={{
                backgroundColor: "skyblue",
                color: "white"
            }}>
                Just for Fun!
            </div>
        );
    }
});
ReactDOM.render(
    <ForExample />,
    document.getElementById("select2")
);
  • ** 第三种**,稍微复杂点,但是可以重复利用,维护起来很方便,而且也很美观:
var forExample = {
    backgroundColor: "skyblue",
    color: "white"
}
var ForExample = React.createClass({
    render: function() {
        return (
            <div style={forExample}>
                Just for Fun!
            </div>
        );
    }
});
ReactDOM.render(
    <ForExample />,
    document.getElementById("select3")
);
  • ** 第三种 plus**,一种充分利用JSON结构来写的样式,更有条理,易于维护和引用:
var colour = {
    text: {
        red: {
            color: "#e65051",
        },
        gray: {
            color: "#a0a0a0",
        },
        white: {
            color: "#FFFFFF",
        }
    },
    bg: {
        red: {
            backgroundColor: "#e65051",
        },
        gray1: {
            backgroundColor: "#ededed",
        },
        gray2: {
            backgroundColor: "#f7f7f7", 
        },
    },
};
var ForExample = React.createClass({
    render: function() {
        return (
            <div style={colour.text.red}>
                Just for Fun!
            </div>
        );
    }
});
ReactDOM.render(
    <ForExample />,
    document.getElementById("select3s")
);

当然,如果你想对一个目标引用多个样式的话,就要用到JSON数据的拼接。方便点,可以引入jQuery文件,使用extend()方法,如:

var ForExample = React.createClass({
    render: function() {
        return (
            <div style={$.extend({}, colour.text.red, colour.bg.red)}>
                Just for Fun!
            </div>
        );
    }
});
  • 第四种,更复杂的动态样式,这就要用到react中的state来重新触发渲染,以下就是一个点击(onClick)后文字变色变大的demo:
var ChangeGame = React.createClass({
    
    getInitialState: function() {
        return {colorX: "skyblue", fontSizeX: "20px"};
    },
    
    guessWhat: function(event) {
        this.setState({colorX: "blue", fontSizeX: "50px"});
    },
    
    render: function() {
        return (
            <div onClick={this.guessWhat} style={{color: this.state.colorX, fontSize: this.state.fontSizeX}}>
                变色,变大!
            </div>
        );
    }
});
ReactDOM.render(
    <ChangeGame />,
    document.getElementById("select4")
);

这里的触发事件也很多,比如onKeyDown、onCopy等等,同样可以做到模拟CSS各事件。

* TO BE CONTINUED!*


然而,这些并不是实际react工程中常用的编写样式的方式,常用的一般是文章开始时提到的一些CSS模块化组件。这些,我们下次再说吧!( •̀ ω •́ )y

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

推荐阅读更多精彩内容