小程序/网页实现textarea高度随内容自动改变

时间: 2018-07-10阅读: 3821标签: 表单

需求

textarea默认的高度不是对着内容变化,而是随着内容增多,出现了滚动条。目前的需求是实现一个能够输入的textarea,并且高度跟着内容变化。

发现了一个比较好用的插件flexText,但是这个基于jquery写的,目前的技术栈是react,所以简单看了下,然后用原生的js模拟了一个实现。


原理:

html结构:
  1. <div class="body">
  2. <div class="container">
  3. <pre class="pre"><span /><br /><br /></pre>
  4. <textarea class="content" placeholder="请输入内容" oninput="changeContent()"></textarea>
  5. </div>
  6. </div>
样式:

最外层的div不需要样式,重点在里面的pre和textarea

textarea绝对定位,高度为100%,也就是高度随着外面container的高度变化。

pre是块元素,占用空间但是不可见。在textarea输入的时候,实时的把内容写入到pre中,因为pre是container的子元素,且所以外层container的高度会被pre的高度撑开。

  1. .container{
  2. position: relative;
  3. }
  4. .content{
  5. position:absolute;
  6. top:0;
  7. left:0;
  8. height:100%;
  9. background: transparent;
  10. outline:0;
  11. resize:none;
  12. overflow:hidden;
  13. }
  14. .container pre {
  15. display:block;
  16. visibility:hidden;
  17. }
js实时把textarea内容写入到pre:
  1. function changeContent(){
  2. var $textarea = document.getElementsByClassName('content');
  3. var $pre = document.getElementsByClassName('pre');
  4. $pre[0].innerhtml = $textarea[0].value;
  5. }


简陋的源码

  1. <!doctype html>
  2. <html>
  3. <head>
  4. <meta charset="utf-8">
  5. <meta name="viewport" content="width=device-width, initial-scale=1">
  6. <style>
  7. .container{
  8. position: relative;
  9. }
  10. .content{
  11. position:absolute;
  12. top:0;
  13. left:0;
  14. height:100%;
  15. background: transparent;
  16. outline:0;
  17. font-size: inherit;
  18. color: inherit;
  19. line-height: inherit;
  20. text-indent: inherit;
  21. letter-spacing: inherit;
  22. resize:none;
  23. overflow:hidden;
  24. }
  25. .container pre {
  26. display:block;
  27. visibility:hidden;
  28. }
  29. </style>
  30. </head>
  31. <body>
  32. <div class="body">
  33. <div class="container">
  34. <pre class="pre"><span /><br /><br /></pre>
  35. <textarea class="content" placeholder="请输入内容" oninput="changeContent()"></textarea>
  36. </div>
  37. </div>
  38. <script>
  39. function changeContent(){
  40. var $textarea = document.getElementsByClassName('content');
  41. var $pre = document.getElementsByClassName('pre');
  42. $pre[0].innerHTML = $textarea[0].value;
  43. }
  44. </script>
  45. </body>
  46. </html>


使用oninput而不是onchange的原因:

onkeyup使用复制粘贴时,高度不能自动改变

onchange事件:在内容改变(两次内容有可能相等)且失去焦点时触发,不能实时同步

oninput事件:HTML5 的标准事件,可以用来检测元素通过用户界面发生的内容变化,在内容修改后立即被触发


小程序中的实现

wxml:

<view class="text-box">
      <text>{{currentInput}}</text>
      <textarea class="weui-textarea" placeholder="请输入文本" bindinput="getInput" maxlength="1000"/>
</view>


wxss:

.text-box{
    width:100%; 
    position: relative;
    min-height:80rpx;
   margin-top:17rpx;
}
.text-box text{
   display:block;
   visibility:hidden;
   word-break:break-all;
   word-wrap:break-word;
}
.text-box .weui-textarea{
    height:100%;
    position: absolute;
    left:0;
    top:0; 
    overflow-y:hidden;
    word-break:break-all;
    word-wrap:break-word;
}


js:

Page({
  data: {
    currentInput:''
  },
  getInput:function(e){
    this.setData({
      currentInput: e.detail.value
    })
  }
})


提醒:默认textarea应该是200个字,如果想要增加字数限制,使用maxlength属性

扩展:如果想给textarea输入的文字加删除线,只需把text的visibility:hidden; 属性去掉,给textarea加一个透明的颜色就可以了。透明颜色:color:rgba(52, 52, 52,0.5);

链接:https://blog.csdn.net/liuwengai/article/details/78987957


站长推荐

1.云服务推荐: 国内主流云服务商,各类云产品的最新活动,优惠券领取。地址:阿里云腾讯云华为云

2.广告联盟: 整理了目前主流的广告联盟平台,如果你有流量,可以作为参考选择适合你的平台点击进入

链接: http://www.fly63.com/article/detial/918

关闭

谷歌浏览器禁止表单自动填充

在项目开发期间发现谷歌浏览器有记住密码的功能,该功能有个问题就是一遇到input type=password就开始自动填充,同一个账户还好,就是bug了。找了一堆解决方案终于找到了办法,下面分享一下解决方案。

HTML5表单新特性

HTML5表单新特性之——新的input typeEmail:邮件输入域,在表单提交时提供简单的邮箱格式验证,并弹出一个提示矿口(可定制内容不能定制样式),url:URL地址输入域。在表单提交时提供简单的URL地址格式验证

关于input的一些问题解决方法分享

input是我们接受来自用户的数据常用标签,在前端开发中:移动端底部input被弹出的键盘遮挡。控制input显/隐密码。在input中输入emoji表情导致请求失败。input多行输入显示换行。输入框首尾清除空格-trim()、在input中监听键盘事件

css input checkbox复选框控件 样式美化的多种方案

checkbox复选框可能是网站中常用的HTML元素,但大多数人并不满意它的默认样式,这篇文章就讲讲如何实现input checkbox复选框控件 样式美化效果。::before和::after伪元素的用法

HTML常用标签之<form>标签

在HTML中,<form></form>标记对用来创建一个表单,即定义表单的开始和结束位置,在标记对之间的一切都属于表单的内容。每个表单元素开始于form元素,可以包含所有的表单控件

表单提交type=submit和type=image的区别

type=image默认是sumbit,不用再添加onclick事件提交,否则会发生表单被提交两次的情况;在onclick事件中添加重置方法

Js使用表单元素验证表单

最简单的HTML结构:网站最基础的就是注册,它是一个系统的交互基础;因为用户最后要去点击\\\"注册\\\"按钮,所以我们就在\\\"注册\\\"按钮上添加一个onclick事件属性,引用eg.regCheck()

Html5中input新增的表单元素和属性介绍。

input标签主要用于Web表单的创建交互,以便接受来自用户的数据。 我们通过更改type属性的值,来实现不同的输入类型。这篇文章主要讲解html5中新增的表单属性。

vue表单校验

两个文件,一个写逻辑,一个写校验规则;特点:逻辑简单,代码量少,够用;不想看代码直接新建这两个文件复制代码,看最下面的使用方法;

css实现修改浏览器自动填充表单的默认样式

当表单中存在input[password]的时候,采用submit方式提交。就会触发浏览器自动填充表单。比如chrome自动填充后,淡黄色输入框代替了背景样式,看起来有些怪异。input文本框是使用图片背景的

点击更多...

内容以共享、参考、研究为目的,不存在任何商业目的。其版权属原作者所有,如有侵权或违规,请与小编联系!情况属实本人将予以删除!