div仿textarea可输入

被刻印的时光 ゝ 提交于 2020-04-06 04:10:26

原本要用textarea,但是后来发现好像只有IE支持textarea里边使用html标签,由于需要在textarea中显示一条横线(<hr />),在网上查了很久,都说textarea是纯文本不能使用html标签,但是可以换成div代替,这下就方便多了,因此放弃textarea,代码如下:

html代码:

1 <div class="textareadiv">
2                 <div id="txtSayWords" contenteditable="true" onfocus="AutoContents('in')" onblur="AutoContents('out')">输入您要说的话...不少于10个字</div>
3                 <div id="replydiv"></div>
4                 </div>
html

CSS代码:

1 .textareadiv{border:1px #ad0d0d solid;resize: none;height:97px;width:671px;padding:9px;color:#848484;font-size:12px;overflow:auto;}
CSS

JS代码:

 1 var defaultVal = "输入您要说的话...不少于10个字"; //默认文本框内容
 2 function AutoContents(type) {
 3     var txtVal = $("#txtSayWords").html(); //文本框获取或失去焦点时的文本框内容
 4     //文本框获取焦点
 5     if (type == "in") {
 6         //主动说话操作
 7         if (txtVal == defaultVal) {//表示内容为空
 8             //清空文本框
 9             $("#txtSayWords").html("");
10         }
11     } else if (type == "out") {//文本框失去焦点
12         //如果内容为除去默认值以外的值,则需自动填充默认值+除默认值以外的
13         //主动说话操作
14         if (txtVal == "") {//没有输入内容
15             //如果焦点离开文本框时内容为空,表示没有输入任何内容,则需自动填充默认值
16             $("#txtSayWords").html(defaultVal);
17         }
18     }
19 }
JS

到这里终于可以完工了,也该下班休息了,呵呵呵!

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!