欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

如何用react優(yōu)雅的書寫CSS

 更新時(shí)間:2021年04月16日 08:34:19   作者:ws_qy  
這篇文章主要介紹了如何用react優(yōu)雅的書寫CSS,幫助大家更好的理解和學(xué)習(xí)使用react,感興趣的朋友可以了解下

1.內(nèi)聯(lián)樣式

優(yōu)點(diǎn):這種方式較為簡(jiǎn)單,一目了然,給標(biāo)簽添加style屬性。

缺點(diǎn): 這種方式可以造成項(xiàng)目結(jié)構(gòu)較為臃腫,造成css命名沖突。

import React, { Component } from 'react'
import PropTypes from 'prop-types'
export default class index extends Component {
    static propTypes = {
     title: PropTypes.string
    }
    render() {
        const h1Style={textAlign:'center',marginBottom:'20px',lineHeight:'35px',
        height:'30px'}
        const {title}=this.props
        return (
         <div>
             <h1 style={h1Style}>{title}</h1>
             <hr/>
         </div>
        )
    }
}

2.使用import導(dǎo)入方式

優(yōu)點(diǎn):這種方式使用起來更加靈巧,類似于css中的外部引入

缺點(diǎn):因?yàn)閞eact樣式默認(rèn)是全局樣式,很有可能造成樣式?jīng)_突

使用:新建css文件,在jsx語法中通過className屬性設(shè)置類名,在css使用類名,這種方式可以使用三元表達(dá)式,通過定義變量來選擇類名。

import React, { Component } from 'react'
import "./index.css"
export default class index extends Component {
    state={
        flag:true
    }
changeColor=()=>{
    this.setState((state,props)=>{
        return{
           flag:!state.flag
        }
    })
}
    render() {
        const {flag}=this.state
        return (
            <div>
                <h1 className={flag?'blueColor':'redColor'}>莫等閑,白了少年頭</h1>
                <button onClick={this.changeColor} className="btnStyle">點(diǎn)擊更改字體顏色</button>
            </div>
        )
    }
}

.blueColor{
    color: blue;
}
.redColor{
    color: red;
}
.btnStyle{
    width: 260px;
    height: 50px;
    background-color: aqua;
    color: #fff;
    border:none;
    font-size: 28px;
    border-radius: 10px;
}

3.css module模塊導(dǎo)出

優(yōu)點(diǎn):不會(huì)造成命名沖突,樣式局部有效

缺點(diǎn):太過麻煩,每次都需要模塊導(dǎo)入導(dǎo)出,相當(dāng)于將css所有類名作為一個(gè)對(duì)象的屬性,在需要使用該對(duì)象屬性時(shí),通過調(diào)用對(duì)象屬性的方式調(diào)用類名,解決css沖突的方式是給不同的類名添加前綴,類似于vue中給style設(shè)置module

使用:

  • 在cra腳手架中只要在父組件中引入了css樣式,那么這個(gè)樣式就是全局樣式
  • 在react中用模塊化來解決樣式?jīng)_突的問題
  • 在cra腳手架中,如果某個(gè)樣式文件要開啟模塊化,只需要把樣式文件命名為xx.module.css/xx.module.scss就可以了

import React,{FC,useState} from "react"
import Cmittem from "@/components1/cmittem"
import cssObj from "./cmtlist.module.scss"
const Cmtlist:FC<{}>=(props)=>{
    return (
        <div>
             <h1 className={cssObj.title}>評(píng)論列表</h1>
       
       </div>
    )
}

export default Cmtlist

4.使用styled-components

優(yōu)點(diǎn): 使用模板字符串標(biāo)簽+樣式組合后是一個(gè)大寫字母開頭表示的組件,比如可以說是將react開發(fā)中最流行的一些寫法整合起來,對(duì)于React開發(fā)者來說,是非常好入手的。那么,在react組件中,使用外部css還是組件css,不同的開發(fā)者習(xí)慣不同。

使用:

需要安裝styled-components

npm i styled-components或者yarn add styled-components

vscode安裝插件便于書寫

4.1初步使用

import 'antd/dist/antd.less'
import styled from 'styled-components'
function App() {
 const HomeWrapper=styled.div`
 font-size:50px;
 color:red;
 span{
   color:orange;
   &.active{
      color:green;
   }
   &:hover{
     color:blue;
     font-size:40px;
   }
   &::after{
     content:'ssss'
   }
   }
 `
  return (
    <div className="App">
 <h1 >我是一個(gè)標(biāo)題</h1>
 <HomeWrapper>
 <h2>我是一個(gè)副標(biāo)題</h2>
   <span>輪播1</span>
   <span className="active">輪播2</span>
   <span>輪播3</span>
   <span>輪播4</span>
 </HomeWrapper>
    </div>
  );
}

export default App;

4.2通過attrs設(shè)置屬性

import 'antd/dist/antd.less'
import styled from 'styled-components'
function App() {
 const ChangeInput=styled.input.attrs({
   placeholder:'wangsu',
   bgColor:'red'
 })`
 background-color:#7a7ab4;
 color:${props=>props.bgColor}
 `
  return (
    <div className="App">
 <h1 >我是一個(gè)標(biāo)題</h1>
 <ChangeInput type="text"/>
    </div>
  );
}

export default App;

4.3css繼承

import React, { Component } from 'react'
import styled from 'styled-components'
const HYbutton=styled.button`
   color:red;
   border:1px solid #ccc;
   padding:10px 20px;
`
//這里使用繼承
const XLbutton=styled(HYbutton)`
background-color:blue;
`
export default class Button extends Component {

    render() {
        return (
            <div>
                <HYbutton>這是一個(gè)按鈕</HYbutton>
                <XLbutton>這是一個(gè)繼承按鈕</XLbutton>
            </div>
        )
    }
}

這幾天在開發(fā)項(xiàng)目時(shí),一直使用的這種方式,感覺很新穎,雖然社區(qū)各有爭(zhēng)議,但是個(gè)人喜歡這種方式設(shè)置css,完全不用考慮全局的樣式問題

以上就是如何用react優(yōu)雅的書寫CSS的詳細(xì)內(nèi)容,更多關(guān)于react 書寫CSS的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • React實(shí)現(xiàn)輪播效果

    React實(shí)現(xiàn)輪播效果

    這篇文章主要為大家詳細(xì)介紹了React實(shí)現(xiàn)輪播效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2020-08-08
  • React Native功能豐富的Toast通知庫

    React Native功能豐富的Toast通知庫

    這篇文章主要為大家介紹了React Native功能豐富的Toast通知庫使用示例,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-10-10
  • react組件中的constructor和super知識(shí)點(diǎn)整理

    react組件中的constructor和super知識(shí)點(diǎn)整理

    這篇文章主要介紹了react組件中的constructor和super知識(shí)點(diǎn)整理,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2021-08-08
  • 一文教你如何避免React中常見的8個(gè)錯(cuò)誤

    一文教你如何避免React中常見的8個(gè)錯(cuò)誤

    這篇文章主要來和大家一起分享在?React?開發(fā)中常見的一些錯(cuò)誤,以及如何避免這些錯(cuò)誤,理解這些問題背后的細(xì)節(jié),防止犯下類似的錯(cuò)誤,需要的可以參考下
    2023-12-12
  • react+antd+upload結(jié)合使用示例

    react+antd+upload結(jié)合使用示例

    這篇文章主要為大家介紹了react+antd+upload結(jié)合使用示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-05-05
  • react項(xiàng)目從新建到部署的實(shí)現(xiàn)示例

    react項(xiàng)目從新建到部署的實(shí)現(xiàn)示例

    這篇文章主要介紹了react項(xiàng)目從新建到部署的實(shí)現(xiàn)示例,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-02-02
  • react中的雙向綁定你真的了解嗎

    react中的雙向綁定你真的了解嗎

    這篇文章主要為大家詳細(xì)介紹了react中的雙向綁定,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助
    2022-03-03
  • React?hooks中useState踩坑之異步的問題

    React?hooks中useState踩坑之異步的問題

    這篇文章主要介紹了React?hooks中useState踩坑之異步的問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2024-03-03
  • React hook超詳細(xì)教程

    React hook超詳細(xì)教程

    Hook是React16.8的新增特性。它可以讓你在不編寫class的情況下使用state以及其他的React特性,這篇文章主要介紹了React hook的使用
    2022-10-10
  • React 組件間的通信示例

    React 組件間的通信示例

    這篇文章主要介紹了React 組件間的通信示例,主要通信劃分為三種,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2018-06-06

最新評(píng)論