올해 초, 나는 텍스트 영역과 입력 상자를 자동으로 확장하는 것에 관한 기사를 썼습니다. 핵심 아이디어는 텍스트 영역을 더 비슷하게 만드는 것입니다.<div> , 현재 값을 수용하기 위해 컨텐츠에 따라 높이가 자동으로 조정되도록합니다. 놀랍게도, 아직이를 달성하기위한 간단한 기본 솔루션은 없습니다. 그 기사를 되돌아 보면, 내가 제시 한 아이디어는 그다지 이상적이지 않았습니다. 그러나 기사의 끝에서 언급 된 Stephen Shaw 제도는 훌륭하므로 더 나은 기본 솔루션을 얻을 때까지 이러한 사용자 경험 문제에 대한 최종 답변 인 것 같습니다. 실행 가능한 예제 만 보려면 데모를 확인하십시오.<h3 id="트릭은-텍스트-영역의-내용을-높이를-자동으로-확장하고-크기를-일치시킬-em-수-em-있는-요소로-정확하게-복사하는-것입니다"> 트릭은 텍스트 영역의 내용을 높이를 자동으로 확장하고 크기를 일치시킬 <em>수</em> 있는 요소로 정확하게 복사하는 것입니다.</h3>
<p> <code><textarea></textarea>
,它无法自动扩展高度。
相反,您需要在另一个元素中精确复制<textarea></textarea>
的外观、内容和位置。您可以隐藏副本的视觉效果(也可以保留实际功能的<textarea></textarea>
可见)。
现在,这三个元素相互关联。最高的子元素会将父元素的高度推高,其他子元素也会随之调整。这意味着<textarea></textarea>
的最小高度将成为“基准”高度,但如果复制的文本元素变得更高,则所有元素都会随之变高。
如此巧妙!我非常喜欢它。
您需要确保复制的元素完全相同
相同的字体、相同的填充、相同的边距、相同的边框……一切都要相同。它是一个完全相同的副本,只是通过visibility: hidden;
隐藏了视觉效果。如果两者不完全相同,则所有元素的高度不会完全同步。
我们还需要在复制的文本上使用white-space: pre-wrap;
,因为这是<textarea></textarea>
的行为方式。
这是最奇怪的部分
在我的演示中,我使用::after
来创建复制的文本。我不确定这是否是最佳方法。对我来说,这感觉很简洁,但我不知道使用<div aria-hidden="true">对于屏幕阅读器是否更安全?或者<code>visibility: hidden;
就足够了吗?无论如何,这还不是最奇怪的部分。最奇怪的部分是:
<code>content: attr(data-replicated-value) " ";</code>
因为我使用的是伪元素,所以这一行将数据属性从元素中获取,并将内容呈现到页面上并添加了一个额外的空格(这就是最奇怪的部分)。如果您不这样做,最终结果会显得“跳跃”。我无法完全理解其中的原因,但它似乎能更好地处理<textarea></textarea>
和文本元素之间的换行符行为。
如果您不想使用伪元素,也可以,但请注意“跳跃”行为。
特别感谢WillEarp和MartinTillmann,他们都在同一天随机发邮件提醒我Shaw的技巧有多么巧妙。这是Martin使用Alpine.js和Tailwind制作的示例,最终也类似于单行代码(但请注意它存在“跳跃”问题)。
我相信大家可以想象如何使用Vue和React等框架来实现这一点,并轻松地在<textarea></textarea>
和其他元素之间维护状态。我不会在这里包含示例,部分原因是我比较懒,但主要是因为我认为您应该理解其工作原理。这将使您更聪明,并更好地理解您的网站。
위 내용은 자가 조영 텍스토리를위한 가장 깨끗한 트릭의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

이것은 우리가 양식 접근성에 대해 한 작은 시리즈의 세 번째 게시물입니다. 두 번째 게시물을 놓친 경우 "사용자 초점 관리 : Focus-Visible"을 확인하십시오. ~ 안에

이 튜토리얼은 Smart Forms 프레임 워크를 사용하여 전문적인 JavaScript 양식을 작성하는 것을 보여줍니다 (참고 : 더 이상 사용할 수 없음). 프레임 워크 자체를 사용할 수 없지만 원칙과 기술은 다른 형태의 건축업자와 관련이 있습니다.

CSS Box-Shadow 및 개요 속성은 주제를 얻었습니다. 실제 테마에서 어떻게 작동하는지에 대한 몇 가지 예와 이러한 스타일을 WordPress 블록 및 요소에 적용 해야하는 옵션을 보자.

Svelte Transition API는 맞춤형 전환을 포함하여 문서를 입력하거나 떠날 때 구성 요소를 애니메이션하는 방법을 제공합니다.

이 기사에서 우리는 스크롤 바의 세계로 뛰어들 것입니다. 너무 화려하게 들리지는 않지만 잘 설계된 페이지가 손을 잡고 있습니다.

웹 사이트의 컨텐츠 프레젠테이션을 설계하는 데 얼마나 많은 시간을 소비합니까? 새 블로그 게시물을 작성하거나 새 페이지를 만들 때

NPM 명령은 서버 시작 또는 컴파일 코드와 같은 것들에 대한 일회성 또는 지속적으로 실행되는 프로세스로 다양한 작업을 실행합니다.


핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

AI Hentai Generator
AI Hentai를 무료로 생성하십시오.

인기 기사

뜨거운 도구

에디트플러스 중국어 크랙 버전
작은 크기, 구문 강조, 코드 프롬프트 기능을 지원하지 않음

ZendStudio 13.5.1 맥
강력한 PHP 통합 개발 환경

안전한 시험 브라우저
안전한 시험 브라우저는 온라인 시험을 안전하게 치르기 위한 보안 브라우저 환경입니다. 이 소프트웨어는 모든 컴퓨터를 안전한 워크스테이션으로 바꿔줍니다. 이는 모든 유틸리티에 대한 액세스를 제어하고 학생들이 승인되지 않은 리소스를 사용하는 것을 방지합니다.

Dreamweaver Mac版
시각적 웹 개발 도구

VSCode Windows 64비트 다운로드
Microsoft에서 출시한 강력한 무료 IDE 편집기
