textarea有value属性吗 overflow属性
今天给各位分享textarea有value属性吗的知识,其中也会对overflow属性进行解释,如果能碰巧解决你现在面临的问题,别忘了关注本站,现在开始吧!
如何让contenteditable元素只能输入纯文本 00 张鑫旭
一、温故而知新
很多年以前,稍等,让我搜一下contenteditable(右上角),哈,是2010年的时候,写了篇文章“div模拟textarea文本域轻松实现高度自适应”,就是说的contenteditable的应用。
虽然说,利用全浏览器都支持的contenteditable模拟文本域可以实现体验相当不错的高度跟随内容自动撑开的效果,但是呢,有个很大的问题就是HTML内容可以直接被粘贴进去,如下图所示:
之前的文章提到过过滤HTML的方法,保证内容都是纯文本。然而,这种方法的问题在于:
粘贴完毕到过滤结束有时间差,用户很看到内容一闪而过的糟糕体验;
光标的位置会发生变化,不是之前focus的位置了;
当年的我图样图森破,所以,只有上面这种程度。实际上,控制contenteditable元素只能输入纯文本是有体验比较好的方法的。
二、与contenteditable属性无关的CSS控制法
一个div元素,要让其可编辑,也就是可读写,contenteditable属性是最常用方法,做前端的基本上都知道。但是,知道CSS中有属性可以让普通元素可读写的的同学怕是就少多了。
主角亮相:user-modify.
支持属性值如下:
user-modify: read-only;
user-modify: read-write;
user-modify: write-only;
user-modify: read-write-plaintext-only;
其中,write-only不用在意,当下这个年代,基本上没有浏览器支持,以后估计也不会有。read-only表示只读,就是普通元素的默认状态啦。然后,read-write和read-write-plaintext-only会让元素表现得像个文本域一样,可以focus以及输入内容。
您可以狠狠地点击这里:CSS user-modify属性行为表现demo
会发现,设置了read-write和read-write-plaintext-only值的两个<p>标签元素是可以被focus的:
而这两者的区别就在于,一个可以输入富文本,而下面一个只能输入纯文本,例如,我们从某网页同时复制一段内容粘贴进去看看:
好了,至此,本文标题的答案实际上就已经有了。也就是给元素设置:
user-modify: read-write-plaintext-only
就可以让元素既可以编辑,也只能输入纯文本,表现得就跟textarea文本域一样。
是不是很酷啊!然而,抱歉地跟大家讲下,目前只有webkit内核浏览器才支持read-write-plaintext-only这个值,因此,我们的使用其实是:
-webkit-user-modify: read-write-plaintext-only
我们可以在移动端使用,以及,只需要兼顾webkit内容的桌面网页项目。
三、使用标准contenteditable属性值的HTML控制法
咳咳,提问:在HTML中,contenteditable支持的属性值是?
图样图森破时候的我,脑中就只有contenteditable="true"和contenteditable="false",科科,后来我发现自己太天真了,新的草案中明确表示还有多个其他属性值:
The contenteditable attribute is an enumerated attribute
whose keywords are the empty string(“”),“events”,“caret”,“typing”,
“plaintext-only”,“true”, and“false”. There is one additional state,
the inherit state, which is the missing value default(and the invalid
value default).
垂直展示下就是(不包括默认的inherit继承):
contenteditable=""
contenteditable="events"
contenteditable="caret"
contenteditable="plaintext-only"
contenteditable="true"
contenteditable="false"
别问我,我也不知道"events"和"caret"是干什么用的,嘿,但是"plaintext-only"我是知道的,可以让编辑区域只能键入纯文本。这里就不需要demo了,直接下面的框框,大家可以试试,看看能不能搞富文本。
<div contenteditable="plaintext-only"></div>
如果您发现,居然出乎意料,可以弄进去富文本,那说明你使用的是非Chrome之流的浏览器。
换句话说,contenteditable="plaintext-only"和CSS只的-webkit-user-modify: read-write-plaintext-only一样,目前仅仅是Chrome浏览器支持比较好的。
所以,您的项目如果还有很多IE8浏览器的用户,我只能替你惋惜,美妙的东西无法立即用上,不得已,寻求下面的方法。
四、控制粘贴paste事件的JS控制法
如果我们单纯地敲击键盘,输入的内容实际上都是纯文本。除了一些特殊情况,例如IE浏览器下的编辑框会自动把合乎条件的url地址自动加上链接。富
文本污染的情况主要出现在复制粘贴的时候,于是,如果我们能在粘贴的时候,对剪切板中的内容进行HTML过滤,再手动插入内容,岂不就可以完美解决无法输
入富文本的问题了吗
关于Swing添加addTextListener
对于Swing中的JTextField类,实现监控的过程则相对复杂一些。JTextField中没有设置TextListener,而是将对文本的监视任务放入了另外一个接口Document中。因此首先要为JTextField对象申请一个Document接口对象,使用的方法是JTextField1.getDocument()(本文给出的JTextField对象名为JTextField1)。获得Document后,就可以使用addDocumentListener()来得到一个和TextListener功能类似的监听接口。DocumentListener的完整声明如下:
interface DocumentListener extends EventListener
它在包java.swing.event.DocumentListener中定义,其中包含了三个方法:
public void changedUpdate(DocumentEvent e):监听文本属性的变化;
public void insertUpdate(DocumentEvent e):监听文本内容的插入事件;
public void removeUpdate(DocumentEvent e):监听文本内容的删除事件。
和处理TextField组件一样,定义新类(本文为Swing_OnValueChanged)、加入说明、编写代码后,就可以实现所需功能了。
编程实现
下面给出实现监控功能的关键部分的Java代码。完整代码编译后在Java虚拟机上运行。
在两个编辑框中或输入或删除或选中后修改,只要文本框中的内容得到了确切的改变,就会触发相应的事件,从而产生输出(在字符界面上)。
public class JFrame1 extends JFrame{
public JFrame1(){//生成图形界面
……
//对Exit按钮的事件定义
btnAction exitAction= new btnAction();
JButton1.addActionListener(exitAction);
//定义TextField组件的文本监听
textField1.addTextListener(new AWT_OnValueChanged());
//定义JTextField组件的文本监听
JTextField1.getDocument().addDocumentListener(new Swing_OnValueChanged());
}
//根据接口TextListener定义新AWT_OnValue
Changed class AWT_OnValueChanged implements TextListener{
public void textValueChanged(TextEvent e){//输出变化及结果
System.out.println(“Text Changed:”+textField1.getText());
}
}
//根据接口DocumentListener定义新类Swing_OnValueChanged
class Swing_OnValueChanged implements DocumentListener{//输出变化及结果
public void changedUpdate(DocumentEvent e){
System.out.println(“Attribute Changed”+e);
}
public void insertUpdate(DocumentEvent e){//输出变化及结果
System.out.println(“Text Inserted:”+textField1.getText());
}
public void removeUpdate(DocumentEvent e){//输出变化及结果
System.out.println(“Text Removed:”+textField1.getText());
}
}
//定义新类,实现Exit按钮的时间监听
class btnAction implements ActionListener{//接收事件
public void actionPerformed(ActionEvent event){
Object object= event.getSource();
if(object== JButton1){
JButton1_actionPerformed(event);
}
}
}
//Exit按钮事件
void JButton1_actionPerformed(java.awt.event. ActionEvent event){//退出程序
System.exit(0);
}
}
小结
实际上,除了文本框(TextField和JTextField),只要是文本编辑区,包括TextArea、JTextArea、JTextPane等,都可以利用上述的方法来实现OnValueChanged()事件,以实现对文本区域内容的监控。
以上代码在JDK 1.2环境下编译通过
关于textarea有value属性吗和overflow属性的介绍到此就结束了,不知道你从中找到你需要的信息了吗 ?如果你还想了解更多这方面的信息,记得收藏关注本站。