这一篇主要是介绍一下,在 flash cookie的制作和使用例子详解一 的基础上怎么使用外部的actionscript3的类也就是as文件,这里主要是看代码,具体的东西不做介绍,不明白的可以看看 flash cookie的制作和使用例子详解一:
http://ylq365.iteye.com/blog/1873382
先定义一下外部的类,这里的这个类是从网上找的一个操作cookie的类,就以这个类做为例子
这个类型的代码如下,类名叫Cookie.as
package {
import flash.net.SharedObject;
public class Cookie {
private var _time:uint;
private var _name:String;
private var _so:SharedObject;
public function Cookie(name:String = "testFlashCookie", timeOut:uint=3600) {
_name = name;
_time = timeOut;
_so = SharedObject.getLocal(name, "/");
}
//清楚超时内容;
public function clearTimeOut():void {
var obj:* = _so.data.cookie;
if(obj == undefined){
return;
}
for(var key in obj){
if(obj[key] == undefined || obj[key].time == undefined || isTimeOut(obj[key].time)){
delete obj[key];
}
}
_so.data.cookie = obj;
_so.flush();
}
public function isTimeOut(time:uint):Boolean {
var today:Date = new Date();
return time + _time * 1000 < today.getTime();
}
//获取超时值;
public function getTimeOut():uint {
return _time;
}
//获取名称;
public function getName():String {
return _name;
}
//清除Cookie所有值;
public function clear():void {
_so.clear();
}
//添加Cookie值
public function put(key:String, value:*):void {
var today:Date = new Date();
key = "key_"+key;
value.time = today.getTime();
if(_so.data.cookie == undefined){
var obj:Object = {};
obj[key] = value;
_so.data.cookie = obj;
}else{
_so.data.cookie[key] = value;
}
_so.flush();
}
//删除Cookie值;
public function remove(key:String):void {
if (contains(key)) {
delete _so.data.cookie["key_" + key];
_so.flush();
}
}
//获取Cookie值;
public function get(key:String):Object{
return contains(key)?_so.data.cookie["key_"+key]:null;
}
//Cookie值是否存在;
public function contains(key:String):Boolean{
key = "key_" + key;
return _so.data.cookie != undefined && _so.data.cookie[key] != undefined;
}
}
}
然后在flash中调用,flash中的调用代码如下:
var myCookie:Cookie= new Cookie();
//导入ExternalInterface类
import flash.external.ExternalInterface;
flash.system.Security.allowDomain("http://localhost");
flash.system.Security.allowDomain("http://127.0.0.1");
//允许任何域都可以访问
flash.system.Security.allowDomain("*");
function setFC(obj:Object){
myCookie.put("userInfo",obj);
}
function getFC():String{
return myCookie.get("userInfo").userName;
return myCookie.getTimeOut();
}
//允许js)调用flash中的getFC(),setFC(),setFCUserObj
ExternalInterface.addCallback("getFC",getFC);
ExternalInterface.addCallback("setFC",setFC);
再就是页面的代码:
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" lang="zh-CN" xml:lang="zh-CN">
<head>
<title>testFC</title>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<style type="text/css" media="screen">
html, body { height:100%; background-color: #ffffff;}
body { margin:0; padding:0; overflow:hidden; }
#flashContent { width:100%; height:100%; }
</style>
<script type="text/javascript">
function setFC(){
var userName = document.getElementById("userName").value;
var obj = new Object();
obj.userName=userName;
obj.sex="m";
thisMovie().setFC(obj);
}
function getFC(){
alert(thisMovie().getFC());
}
//搭建js与flash互通的环境
function thisMovie() {
if (navigator.appName.indexOf("Microsoft") != -1) {
return window["testFC"];
}else{
return document["testFC"];
}
}
</script>
</head>
<body>
<input type="text" name="userName" id="userName" value="" />
<input type="button" onclick="setFC()" value="setFC" />
<input type="button" onclick="getFC()" value="getFC" />
<div id="flashContent">
<object classid="clsid:d27cdb6e-ae6d-11cf-96b8-444553540000" codebase="http://download.macromedia.com/pub/shockwave/cabs/flash/swflash.cab#version=7,0,19,0" width="1" height="1" id="testFC" title="testFC" align="middle">
<param name="allowScriptAccess" value="always" />
<param name="movie" value="testFC.swf">
<param name="quality" value="high">
<param name="wmode" value="transparent" />
<embed src="testFC.swf" name="testFC" quality="high" allowScriptAccess="always" swLiveConnect="true" pluginspage="http://www.macromedia.com/go/getflashplayer" type="application/x-shockwave-flash" width="1" height="1"></embed>
</object>
</div>
</body>
</html>
运行上面的代码就可以看到我们希望的结果。用这样的方法,我们可以单独的写一些类出来,然后在flash里调用,代码更加结构化,更高的重用性等。
分享到:
相关推荐
本资源“HTML 5开发精要与实例详解(案例源码)”旨在提供深入理解和实践HTML5的关键知识。 1. **新元素的引入**:HTML5引入了许多新的结构性元素,如、、、和等,这些元素有助于提高页面的语义性和可读性,让搜索...
《HTML5开发精要与实例详解》这本书无疑是帮助开发者深入理解并熟练运用HTML5的重要资源。书中的源码部分提供了丰富的实践示例,使得理论知识能够得以具体应用。 在HTML5中,新增了许多元素,比如`<article>`、`...
2. **多媒体支持**:HTML5引入了`<audio>`和`<video>`元素,使网页可以直接嵌入音频和视频内容,无需Flash等插件。开发者可以轻松地控制播放、暂停、音量等属性,同时还支持多种编码格式,如MP4、WebM和Ogg。 3. **...
代码如下: //JS操作cookies方法! //写cookies function setCookie(name,value) { var Days = 30; var exp = new Date(); exp.setTime(exp.getTime() + Days*24*60*60*1000); [removed] = name + “=”+ escape ...
【PHP许愿墙实例开发详解】 在Web开发领域,PHP是一种广泛应用的服务器端脚本语言,尤其在构建动态网站和交互式应用方面表现突出。"Flexsns-sky完全FLASH许愿天空"是一个基于PHP实现的许愿墙示例,它结合了PHP与...
2. **ModelAndView**:如果视图和模型数据都需确定,可直接返回`ModelAndView`实例。 ### 四、视图解析与EL表达式 1. **视图解析**:Spring MVC使用视图解析器(如InternalResourceViewResolver)将逻辑视图名转换...
**Node.js + MongoDB + Express + EJS + Connect-Mongo 知识点详解** Node.js 是一个基于 Chrome V8 引擎的 JavaScript 运行环境,它允许开发者在服务器端使用 JavaScript,提供了丰富的库和框架来简化开发流程。在...
16:PHP小偷程序原理和实例 17:PHP面向对象开发的学习(一) 18:PHP面向对象开发的学习(二) 19:PHP面向对象开发的学习(三) 20:PHP面向对象开发的学习(四) 21:PHP面向对象开发的学习(五) 22:PHP面向...
- **多媒体元素**:项目中还包含了视频、音频和Flash等多媒体元素的插入,增强了网页的表现力和趣味性。 #### 四、代码实例分析 下面展示一个简单的HTML结构代码示例: ```html <!DOCTYPE html> ...
- **实例特性、源代码、功能概述、程序详解**:具体案例演示如何运用JavaScript和Cookie实现特定功能。 #### 第21章:时钟日历 - **示例特性、源代码、功能概述、程序详解**:展示如何使用JavaScript创建动态时钟...
PHP100视频教程16:PHP小偷程序原理和实例 PHP100视频教程17:PHP面向对象开发的学习(一) PHP100视频教程18:PHP面向对象开发的学习(二) PHP100视频教程19:PHP面向对象开发的学习(三) PHP100视频教程20:...
它利用P2P技术,允许两个或多个Flash Player实例之间进行直接的数据交换,而无需通过服务器转发,从而减少了延迟并提高了效率。 #### 二、RTMFP协议的连接建立过程 ##### 1. Handshake Stage 1 (握手阶段1) **...
LocalStorage的引入,解决了早期存储技术如Cookie容量有限和兼容性问题,极大地提高了用户体验和应用程序的性能。 LocalStorage的主要优势在于其较大的存储空间,官方建议每个网站可以使用5MB,这对于存储文本数据...
6. **Web Workers和Web Storage**:Web Workers使得后台处理成为可能,提高网页性能,而Web Storage(包括localStorage和sessionStorage)提供了比传统cookie更大的存储空间,改善用户数据管理。 7. **Geolocation...
### HTML5 技巧二详解 #### 8. 占位符 占位符属性是HTML5中的一个重要改进,它允许开发人员直接在输入框中设置提示文本,从而提高用户体验。以前,为了实现类似功能,通常需要借助JavaScript来动态设置和清除提示...
- 第10章:讲解Web Storage和Web SQL Database两种数据存储API,前者类似于Cookie和Session,后者则允许在JavaScript中直接操作数据库。 - 第11章:介绍Geolocation API的应用,包括与Google Maps API结合实现位置...
随着技术的发展,Canvas有望在未来成为一种替代Flash的方案。 - **第3章:CSS3** CSS3带来了许多新的特性和改进,使得开发者能够更容易地创建复杂的视觉效果和动画。本章将详细介绍如何使用CSS3实现各种视觉效果...
在这个例子中,客户端能够接受多种图像格式、Flash内容以及其他类型的数据。 - **Referer**: 表示发起此请求的页面地址。这对于追踪用户来源很有帮助。 - **Accept-Language**: 指定了客户端首选的语言设置,这里为`...
4. **Video音频播放** - HTML5新增和元素,使得在网页中内嵌视频和音频变得更加简单,无需依赖Flash等外部插件。同时支持多个编码格式如MP4、WebM和Ogg,以兼容不同的浏览器。 5. **离线存储** - 通过离线存储...