1.styled components官网网址
 
以组件的形式来写样式。
1.1安装
yarn add styled-components
1.2
写法依托于ES6和webpack。
 
 

2.Getting Started万物皆组件

 
把样式定义在组件中
import styled from 'styled-components'
 
const Title = styled.h1`          //h1是标签名,就是<h1></h1>
font-size: 1.5em;
text-align: center;
color: palevioletred;
`
 
const Wrapper = styled.section`
padding: 4em;
background: papayawhip;
`
 
export {
Title,
Wrapper
}
 
 
 
在正式文件中引入把样式定义成组件的文件。
import {Wrapper,Title}  from ’......‘
 
class App extends Component{
    render(){
         <Wrapper>
               <Title>hello<Title>
         </Wrapper>
    }
}
 
 

3.Adapting based on props适配属性

给标签传递属性,在样式组件中去接这个属性。
import styled from 'styled-components'
 
const Title = styled.h1`
font-size: 1.5em;
text-align: center;
color: ${props => props.color};               //在组件内部写一个箭头函数来接收参数。通过props获得父组件传过来的参数
background: ${props => props.primary ? "palevioletred" : "white"};
`
 
const Wrapper = styled.section`
padding: 4em;
background: papayawhip;
`
 
export {
Title,
Wrapper
}
 
在正式文件中引入把样式定义成组件的文件。
import {Wrapper,Title}  from ’......‘
 
class App extends Component{
    render(){
         <Wrapper>
               <Title color=‘red’ primary>hello<Title>       //写一个属性,往样式组件中传参。
         </Wrapper>
    }
}
 

4.Extending Styles扩展样式

用途:1.继承样式,在原有的样式基础上做一些更新。
      2.定义好一组样式,想把这组样式应用到另外一组样式上去。
 
import styled from 'styled-components'
 
const Button = styled.button`
  color: palevioletred;
  font-size: 1em;
  margin: 1em;
  padding: 0.25em 1em;
  border: 2px solid palevioletred;
  border-radius: 3px;
`
 
const TomatoButton = styled(Button)`         //此组件继承上一个组件样式,并增加新的样式
  color: tomato;
  border-color: tomato;
`
 
export {
  Button,
  TomatoButton
}
 
在正式文件中引入把样式定义成组件的文件。
import {Button,TomatoButton}  from ’......‘
 
class App extends Component{
    render(){
         <div>
             <Button as="a">按钮</Button>       //as的用处是我们可以定义好一个样式组件,用as换成另外一个标签,如这个就换成了a标签。
              <TomatoButton>按钮</TomatoButton>
         </div>
    }
}
 
 

5.Styling any components样式化很多组件

import React from 'react'
import styled from 'styled-components'
 
const Link = (props) => (               //普通组件,不是样式组件
  <div>
     <a className={props.className}>       //必须写,需要用它接收一下增强的样式。
         {props.children}                //children可以拿到插槽里的内容
     </a>
      <a>
          {props.children}
      </a>
   </div>
)
 
const StyledLink = styled(Link)`      //给Link定义样式,给本来没有样式的组件加上样式
  color: palevioletred;
  font-weight: bold;
`
 
export {
   Link,
   StyledLink
}
 
在正式文件中引入把样式定义成组件的文件。
import {Link,StyledLink}  from ’......‘
 
class App extends Component{
    render(){
         <div>
             <StyledLink>hello</StyledLink>
         </div>
    }
}
 

6.Passed props传递属性、默认属性

import styled from 'styled-components'
 
const Input = styled('input')`
  padding: 0.5em;
  margin: 0.5em;
  color: ${ props => props.inputColor };
  background: papayawhip;
  border: none;
  border-radius: 3px;
`
 
export {
  Input
}
 
在正式文件中引入把样式定义成组件的文件。
import {Input}  from ’......‘
 
class App extends Component{
    constructor(){
         super()
         this.state ={
             value:"aaa"
        }
    }
 
    render(){
         <div>
              <Input defaultValue={this.state.value}></Input>  //给input框设置一个默认值。自定义一个属性,会继承下去,很重要哦!
             <Input inputColor="rebeccapurple"></Input>
         </div>
    }
}
 

7.Coming from CSS直接引css

import React from 'react'
import styles from './styles.css'
 
export default class Counter extends React.Component {
  state = { count: 0 }
 
  increment = () => this.setState({ count: this.state.count + 1 })
  decrement = () => this.setState({ count: this.state.count - 1 })
 
  render() {
    return (
      <div className={styles.counter}>
        <p className={styles.paragraph}>{this.state.count}</p>
        <button className={styles.button} onClick={this.increment}>
          +
        </button>
        <button className={styles.button} onClick={this.decrement}>
          -
        </button>
      </div>
    )
  }}
 

8.Attaching additional props链接额外组件在props上

import styled from 'styled-components'
 
const StyledDiv = styled.div.attrs({    //给标签加自己的属性,但不能是自定义属性。
  title: 'aaa',
  id: 'bbb',
  'data-src': (props) => props.hello         //可以进行欲添加。
})`
font-size: 100px;
> span {
font-size: 50px;
}
& > span {
font-size: 25px;
}
`
 
export {
StyledDiv
}
在正式文件中引入把样式定义成组件的文件。
import {StyledDiv}  from ’......‘
 
class App extends Component{
 
    render(){
        return(
            <StyleDiv hello="hi'>
                hello
                    <span>hahah</span>
            </StyleDiv>
     )
}
 
 
 
 
 

styled components草根中文版文档的更多相关文章

  1. Android SDK API (2.2,2.3,3.0)中文版文档

    转的一篇.觉得很有用. Android SDK API (2.2,2.3,3.0)中文版文档 地址:http://android.laoguo.org固定连接:http://www.laoguo.or ...

  2. 深度学习框架: Keras官方中文版文档正式发布

    今年 1 月 12 日,Keras 作者 François Chollet‏ 在推特上表示因为中文读者的广泛关注,他已经在 GitHub 上展开了一个 Keras 中文文档项目.而昨日,Françoi ...

  3. Aspose.Cells API 中文版文档 下载

    链接: https://pan.baidu.com/s/19foJyWgPYvA7eIqEHJ_IdA 密码: yxun

  4. DBImport v3.44 中文版发布:数据库数据互导及文档生成工具(IT人员必备)

    前言: 距离上一个版本V3.3版本的文章发布,已经是1年10个月前的事了. 其实版本一直在更新,但也没什么大的功能更新,总体比较稳定,所以也不怎么写文介绍了. 至于工作上的事,之前有半年时间跑去学英语 ...

  5. 英文VS2010安装中文版MSDN文档方法

    英文VS2010安装中文版MSDN文档方法 2010-06-01 11:52 by 李永京, 51409 阅读, 50 评论, 收藏, 编辑 在2010年4月12号发布Visual Studio 20 ...

  6. [中文版] 可视化 CSS References 文档

    本文分享了我将可视化 CSS References 文档翻译成中文版的介绍,翻译工作还在陆续进行中,供学习 CSS 参考. 1. 可视化 CSS References 文档介绍 许多 CSS 的文档都 ...

  7. TensorFlow 官方文档中文版 --技术文档

    1.文档预览 2.文档下载 TensorFlow官方文档中文版-v1.2.pdf 提取码:pt7p

  8. 【转】(五)unity4.6Ugui中文教程文档-------概要-UGUI Interaction Components

    原创至上,移步请戳:(五)unity4.6Ugui中文教程文档-------概要-UGUI Interaction Components 4.Interaction Components 本节涵盖了处 ...

  9. 【转】(四)unity4.6Ugui中文教程文档-------概要-UGUI Visual Components

    原创至上,移步请戳:(四)unity4.6Ugui中文教程文档-------概要-UGUI Visual Components 3.Visual Components 有新的组件和游戏对象已添加到uG ...

随机推荐

  1. SpringBoot入门教程(五)Java基于MySQL实现附近的人

    “附近的人”这个功能估计都不陌生,与之类似的功能最开始是在各大地图应用上接触过,比如搜附近的电影院,附近的超市等等.然而真正让附近的人火遍大江南北的应该是微信"附近的人"这个功能, ...

  2. centos7安装xfce桌面

    用了centos自带的gnome桌面 太重了 启动超慢 内存占用近2G 因此打算换一个轻量级的桌面xfce 先安装桌面协议yum groupinstall "X Window system& ...

  3. [整理+原创]ubuntu Thunderbird Mail设置自动提醒

    开机启动的设置方法 // 在终端输入 gnome-session-properties 然后添加thunderbird为启动项 方法1——自动提醒 下载插件:Thunderbird Mail客户端菜单 ...

  4. [十五]java.math包简介,RoundingMode与MathContext

    java.math包提供了java中的数学类 包括基本的浮点库.复杂运算以及任意精度的数据运算   '可以看得到,主要包括三个类一个枚举 BigDecimal和BigInteger接下来会详细介绍 先 ...

  5. 痞子衡嵌入式:串口调试工具Jays-PyCOM诞生记(2)- 界面构建(wxFormBuilder3.8.0)

    大家好,我是痞子衡,是正经搞技术的痞子.今天痞子衡给大家介绍的是串口调试工具Jays-PyCOM诞生之界面构建. 一个软件的UI界面是非常重要的,这是软件与用户交互的接口,软件功能即使再强大,但如果没 ...

  6. 一统江湖的大前端(5)editorconfig + eslint——你的代码里藏着你的优雅

    <一统江湖的大前端>系列是自己的前端学习笔记,旨在介绍javascript在非网页开发领域的应用案例和发现各类好玩的js库,不定期更新.如果你对前端的理解还是写写页面绑绑事件,那你真的是有 ...

  7. javascript基础修炼(5)—Event Loop(Node.js)

    开发者的javascript造诣取决于对[动态]和[异步]这两个词的理解水平. 一. 一道考察异步知识的面试题 题目是这样的,要求写出下面代码的输出: setTimeout(() => { co ...

  8. 安装VS2010时出现进入的图标没有与需要部分升级VS10Sp1-KB983509的解决方案

    大家好,今天又想到需要写一下博客了,毕竟感觉应该在新人入公司的时候可能需要将你电脑上的开发环境进行修改. 下面讲的主要是将VS2012卸载后,重新安装VS2010,. 我遇到了这种情况:在我将VS20 ...

  9. [Linux] memache打印所有的key

    1.在使用memcache的时候 , 经常需要查看下里面存储的值 , 前提是要先知道key是啥,memcache没有redis的keys命令 2.下面两个命令的结合,可以查看到key stats it ...

  10. PHP中使用 fsockopen curl 模拟异步处理

    PHP它最大缺点就是无法实现多线程管理,其程序的执行都是从头到尾,按照逻辑一路执行下来,不可能出现分支,这一点是限制php在主流程序语言中往更高级的语言发展的原因之一. 在PHP中我们有的时候其实希望 ...