分享

textarea 无边框无滚动条自适应高度的实现

 燮羽 2010-11-13

<%@ Page Language="C#" AutoEventWireup="true" CodeFile="TextArea.aspx.cs" Inherits="TextArea" %>

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www./TR/xhtml1/DTD/xhtml1-transitional.dtd">

<html xmlns="http://www./1999/xhtml" >
<head runat="server">
    <title>textarea 无边框无滚动条自适应高度的实现</title>
    <style type="text/css">...
        .info {...}{ 
          font-size: 12px; 
          overflow:hidden;
          background-color: #ffffcc; 
          color: black; 
          width:100%; 
          line-height:12px; 
          padding-right:5px; 
          padding-left:5px; 
          font-family: courier; 
          width:100%; 
          letter-spacing:0;  
          border-style:none; 
        }
    </style>
    <script language="javascript" type="text/javascript">
    function setRows(obj){ 
      var textarea = obj;
      var cols = textarea.cols; 
      var str = textarea.value; 
      str = str.replace(/ ?/, " "); 
      var lines =  textarea.rows; 
      var chars = 0; 
      for (i = 0; i < str.length; i++) { 
        var c = str.charAt(i); 
        chars++; 
        if ( c == " ")
        {
           lines ++; 
        }
        else
        {
           if (i > lines * (cols/2) )      //这里是中文模式除2 如果是输入英文字符修改为1 即可
           {
              lines ++; 
           }
        }
      } 
     textarea.setAttribute("rows", lines); 
     textarea.style.height = lines*12 + "px"; 
    } 
    </script>
</head>
<body>
    <form id="form1" runat="server">
    <div>
    <textarea id='LogC' onkeyup='setRows(this)' class='info' cols='75'rows='12'>可以根据内容自适应调整高度</textarea>
    </div>
    </form>
</body>
</html>

    本站是提供个人知识管理的网络存储空间,所有内容均由用户发布,不代表本站观点。请注意甄别内容中的联系方式、诱导购买等信息,谨防诈骗。如发现有害或侵权内容,请点击一键举报。
    转藏 分享 献花(0

    0条评论

    发表

    请遵守用户 评论公约

    类似文章 更多