仅在手机上呈现带有状态的 div

Posted

技术标签:

【中文标题】仅在手机上呈现带有状态的 div【英文标题】:Render div with state only on phones 【发布时间】:2022-01-16 08:31:48 【问题描述】:

有什么方法可以有条件地渲染 div 状态,但仅适用于手机? 我有显示更多按钮,但我只需要它用于电话分辨率,我还需要每次在桌面上显示带有 className 文本的 div

const ListItem = ( text ) => 
    let [showMore, setShowMore] = useState(false);

    return (
        <div className="item">
            <div>
                <div className=`text $showMore ? "active" : ""`>text</div>
            </div>
            <button onClick=() => setShowMore((s) => !s)>Show more</button>
        </div>
    );
;

【问题讨论】:

【参考方案1】:

您可以在媒体查询中设置活动类。

起初,你可以让这个 div 不显示任何内容。当您的分辨率是电话时,您设置显示块。

.active
        display: none;
    

    @media screen and(max-widht: '400px') 
       .active
            display: block;
       
    

【讨论】:

【参考方案2】:

您可以使用纯 CSS 或使用挂钩进行媒体查询,如下所示:

import useMediaQuery, useMediaQueries from '@react-hook/media-query'
 
// Using a single media query
const Component = () => 
  const matches = useMediaQuery('only screen and (min-width: 400px)')
  return `Matches? $matches ? 'Matched!' : 'Nope :(')`

 
// Using multiple media queries
const Component = () => 
  const matches, matchesAny, matchesAll = useMediaQueries(
    screen: 'screen',
    width: '(min-width: 400px)'
  )
 
  return (
    <div>
      Screen matched? matches.screen ? 'Yes' : 'No'
      Width matched? matches.width ? 'Yes' : 'No'
      All matched? matchesAll ? 'Yes' : 'No'
      Any matched? matchesAny ? 'Yes' : 'No'
    </div>
  )

import useMediaQuery, useMediaQueries from '@react-hook/media-query'
  
// Using multiple media queries
const Component = () => 
  const matches, matchesAny, matchesAll = useMediaQueries(
    screen: 'screen',
    width: '(max-width: 767px)'
  )
 
  return (
    matches.screen ? (<div>Display on mobile</div>) : ''
  )

请注意,此解决方案依赖于this addon

【讨论】:

以上是关于仅在手机上呈现带有状态的 div的主要内容,如果未能解决你的问题,请参考以下文章

[转] 设置div的overflow:scroll,但是在手机上滑动的时候有点卡顿

contenteditable设置元素可编辑

将状态更改应用于 React 中数组的特定索引

如何在手机上隐藏导航栏?

React 状态不会更新,并且列表不会重新呈现

华为荣耀畅玩5在手机上怎么root