TextEvent很有意思,就两个常量,应用场景还截然不同。
TEXT_INPUT:用户输入文本时调用
此时: TextEvent.text:返回用户输入的内容
还有一个类似的用法,是Event.Change。让我们比较一下两者的区别:
1. 触发范围不同
TEXT_INPUT:输入文本时触发。
CHANGE:文本字符发生变化时触发。所以不仅输入文本会触发,删除文本也会触发。
2. 触发时间不同
TEXT_INPUT:在文本填充字符之前先触发
CHANGE:在文本填充字符完成后触发
我举个例子大家就明白意思了:在舞台上创建一个输入文本,实例名为t,在第一帧添加代码如下:
function p1(event:Event):void {
trace(event.type+":"+event.target.text);
}
t.addEventListener(Event.CHANGE, p1);
function p2(event:TextEvent):void {
trace(event.type+":"+event.target.text);
}
t.addEventListener(TextEvent.TEXT_INPUT, p2);
运行后,输入字符“w”,返回结果如下:
textInput: //此时t还没有内容
change:w //此时t已经有内容了
最后说一下TextEvent.text的返回值:
每输入一次字符,将会调用一次函数。你直接输入“my”,那么依次返回“m”“y”。你输入“我们”,即使某些输入法可以修改后一起输入,但还是依次返回“我”“们”。只有一种情况例外:如果你是复制粘帖上去的“我们”,恭喜你,你终于一次性返回了“我们”二字。
TEXT_LINK:启用 HTML 的文本字段中,单击超链接时触发
此时:TextEvent.text:<a> 标签的 href 属性的 event 属性的文本(很拗口吧 ^_^)
例如:
messages.htmlText = "<a href=\"event:http://www.baidu.com\">22</a>";
那么TextEvent.text返回的是“http://www.baidu.com”
注意:
1. 必须要有“event:”不然该监听无效
2. 因为加了“event:”,所以超链接无效了,不会发生页面跳转。
如果一定要跳转,自己加个处理吧,我把我的代码贴出来,仅供参考:
messages.htmlText = "<a href=\"event:http://www.baidu.com\">百度链接</a>";
function p(event:TextEvent):void
{
var url:URLRequest = new URLRequest(event.text);
navigateToURL(url); //AS3.0后,GetURL方法不适用了
}
messages.addEventListener(TextEvent.LINK, p);