您的位置是:网站首页>Javascript编程Javascript编程

react组件添加样式的方法

少儿编程网2021-05-28 14:06:16Javascript编程 人已围观 来源:少儿编程 -用户投稿

简介react组件添加样式的方法:1、通过表达式传入样式对象的方式来实现;2、通过使用行内样式;3、通过第三方包定义类名;4、通过样式组件“styled-components”添加样式。该方法适用于所有品牌的电脑。React组件添加样式的四种方式组件中DOM样式第一种:行内样式想给虚拟dom添加行内样式

react组件添加样式的方法:1、通过表达式传入样式对象的方式来实现;2、通过使用行内样式;3、通过第三方包定义类名;4、通过样式组件“styled-components”添加样式。eeG少儿编程网-https://www.pxcodes.com

eeG少儿编程网-https://www.pxcodes.com

  • 该方法适用于所有品牌的电脑。
    eeG少儿编程网-https://www.pxcodes.com

React组件添加样式的四种方式eeG少儿编程网-https://www.pxcodes.com

组件中DOM样式eeG少儿编程网-https://www.pxcodes.com

第一种:行内样式eeG少儿编程网-https://www.pxcodes.com

想给虚拟dom添加行内样式,需要使用表达式传入样式对象的方式来实现:eeG少儿编程网-https://www.pxcodes.com

// 注意这里的两个括号,第一个表示我们在要JSX里插入JS了,第二个是对象的括号
 <p style={{color:'red', fontSize:'14px'}}>Hello world</p>

行内样式需要写入一个样式对象,而这个样式对象的位置可以放在很多地方,例如render函数里、组件原型上、外链js文件中eeG少儿编程网-https://www.pxcodes.com

第二种:className(外部引用)eeG少儿编程网-https://www.pxcodes.com

React推荐我们使用行内样式,因为React觉得每一个组件都是一个独立的整体eeG少儿编程网-https://www.pxcodes.com

其实我们大多数情况下还是大量的在为元素添加类名,但是需要注意的是,class需要写成className(因为毕竟是在写类js代码,会收到js规则的限制,而class是关键字)eeG少儿编程网-https://www.pxcodes.com

<p className="hello" style = {this.style}>Hello world</p>

第三种:classname/classnames第三方包定义类名eeG少儿编程网-https://www.pxcodes.com

有时候需要根据不同的条件添加不同的样式,比如:完成状态,完成是绿色,未完成是红色。那么这种情况下,我们推荐使用classname/classnames这个包:eeG少儿编程网-https://www.pxcodes.com

<p
    className = { 
        classname({
            size: true,
            bg: true
        })
    }
> 第三包classname定义 </p>

第四种:样式组件(styled-components)eeG少儿编程网-https://www.pxcodes.com

styled-components是针对React写的一套css-in-js框架,简单来讲就是在js中写css。npm链接eeG少儿编程网-https://www.pxcodes.com

styled-components是一个第三方包,要安装eeG少儿编程网-https://www.pxcodes.com

const Container = styled.div`
    width: 100px;
    height: 100px;
    background: pink;
    color: white;
`

以上就是react组件添加样式的方法的详细内容,更多请关注少儿编程网其它相关文章!eeG少儿编程网-https://www.pxcodes.com

来源:php中文网eeG少儿编程网-https://www.pxcodes.com


相关文章:

支持一下 ( )

react组件添加样式的方法

      匿名评论
    • 评论
    人参与,条评论
    react组件添加样式的方法

微信公众号

免费视频教程

先知道