用仿ActionScript的语法来编写html5——第九篇,仿URLLoader读取文件

原创 2011年09月26日 21:39:43

第九篇,仿URLLoader读取文件

先看看最后的代码

function readFile(){
	urlloader = new LURLLoader();
	urlloader.addEventListener(LEvent.COMPLETE,readFileOk);
	urlloader.load("../file/test.txt","text");
}
function readFileOk(){
	mytxt.text = urlloader.data;
}

基本上已经实现了Actionscript的模仿了。

效果和代码看这里,看不到效果的请下载支持html5的浏览器

http://fsanguo.comoj.com/html5/jstoas09/index.html


下面说说实现过程
其实javascript中的ActiveXObject是可以实现本地文件的读写的,但是你的浏览器的安全级别必须设定到最低,但是我们做的游戏和网页是要放到网上的,我们没有办法要求所有的用户这样做。

在这里,我用php来实现这一过程,php可以自由读取服务器上的文件,它并不依赖用户的浏览器的设定

用php读取文件很简单,一个fopen函数就可以搞定,下面是file.php的代码

if(!file_exists($_POST["file"])){
		echo "";
		exit;
	}
	$file = fopen($_POST["file"],"r");
	$filemsg = "";
	while (!feof($file)) {
		$line = fgets($file);
		$filemsg = $line;
	}
	fclose($file);
	echo $filemsg;
把这个php放到你喜欢的位置,然后在legend.js里面设定路径LEGEND_FILE_PHP指向你放的位置

关于javascript调用php,当然可以自己写,因为它并不算复杂,但是我是一个很懒的人,所以我直接用jquery来调用了,jquery是什么?估计不用我解释了吧

关于LURLLoader的构造,和LLoader基本一样,只有load方法不一样,下面是LURLLoader类的完整代码,里面调用了之前准备的php来获取要读取的文本

function LURLLoader(){
	var self = this;
	self.objectindex = ++LGlobal.objectIndex;
	self.type="LURLLoader";
	self.loadtype = "";
	self.content = null;
	self.oncomplete = null;
	self.event = {};
}
LURLLoader.prototype = {
	addEventListener:function(type,listener){
		var self = this;
		if(type == LEvent.COMPLETE){
			self.oncomplete = listener;
		}
	},
	load:function (path,loadtype){
		var self = this;
		self.loadtype = loadtype;
		if(self.loadtype == "text"){
			$.post(LEGEND_FILE_PHP, {
				flg:"read",
				file:path
			},function(data){
				if(self.oncomplete){
					self.event.currentTarget = data;
					self.data = data;
					self.oncomplete(self.event);
				}
			});
		}
	}
}


关于上面的例子,我加了一个按钮,一个LTextField,代码看下面

init(40,"mylegend",600,500,main);

var loadingLayer;
var backLayer;

var urlloader
var mytxt;
function main(){
	legendLoadOver();
	
	var readBtn = addButton("读取",20);
	readBtn.x = 10;
	readBtn.y = 20;
	addChild(readBtn);
	readBtn.addEventListener(LMouseEvent.MOUSE_DOWN, readFile);
	
	mytxt = new LTextField();
	mytxt.x = 10;
	mytxt.y = 50;
	mytxt.text = "";
	mytxt.width = 300;
	mytxt.height = 200;
	mytxt.setType(LTextFieldType.INPUT);
	addChild(mytxt);
}
function readFileOk(){
	mytxt.text = urlloader.data;
}
function readFile(){
	urlloader = new LURLLoader();
	urlloader.addEventListener(LEvent.COMPLETE,readFileOk);
	urlloader.load("../file/test.txt","text");
}
function addButton(lbl,x){
	var up = new LSprite();
	up.graphics.drawRect(1,"black",[0, 0, 80, 20],true,"#999999");
	var txt = new LTextField();
	txt.x = x;
	txt.text = lbl;
	up.addChild(txt);
	var over = new LSprite();
	over.graphics.drawRect(1,"black",[0, 0, 80, 20],true,"#cccccc");
	var txt1 = new LTextField();
	txt1.x = x;
	txt1.text = lbl;
	over.addChild(txt1);
	var btn = new LButton(up,over);
	return btn;
}


over,模仿ActionScript读取文本文件完成了




用仿ActionScript的语法来编写html5——第七篇,自定义按钮

第七篇,自定义按钮 这次弄个简单点的,自定义按钮。 其实,有了前面所定义的LSprite,LBitmap等类,定义按钮就很方便了。 下面是添加按钮的代码, function gameI...
  • lufy_Legend
  • lufy_Legend
  • 2011-09-21 18:41:44
  • 5207

仿天猫html5

  • 2015年11月30日 11:06
  • 3.7MB
  • 下载

使用HTML5编写的移动端仿淘宝页面

  • 2017年10月16日 17:39
  • 1MB
  • 下载

html5 微信朋友圈 场景应用源码 仿云来

  • 2015年02月18日 13:53
  • 40.75MB
  • 下载

html5仿来电界面

  • 2015年09月13日 20:29
  • 60KB
  • 下载

HTML5高仿Win8桌面

  • 2016年01月24日 12:01
  • 42KB
  • 下载

css+html5仿写淘宝首页

问题定义 为了锻炼自己原生的能力,我决定仿写一下淘宝的首页。一下记录,仿写的全部步骤。按照软件工程的方法来实现。(ps,纯为学习,没有什么不良居心~~) 可行性研究技术采用原生js+html5+c...
  • qq_28300493
  • qq_28300493
  • 2016-08-19 17:03:20
  • 3647

仿Windows桌面(HTML5+CSS3)

emmm 自学HTML5的过程中做了一个仿Windows的界面比较粗糙 记录一下=-=<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 ...
  • Asatoga
  • Asatoga
  • 2018-02-13 17:25:03
  • 190

HTML5+CSS+JavaScript仿百度登录之后的静态首页

这是仿百度登录后的静态页面,其中有些功能还不完善,但是我会尽量去完善他们,在这个页面里面有很多相对我来说比较难的地方,比如其中的“更多产品”,“设置”,“换肤功能”,“我的关注,推荐,导航”选项卡之间...
  • qq_32154641
  • qq_32154641
  • 2017-10-24 10:07:06
  • 755

仿淘宝html5主页

  • 2016年10月31日 17:04
  • 1.02MB
  • 下载
收藏助手
不良信息举报
您举报文章:用仿ActionScript的语法来编写html5——第九篇,仿URLLoader读取文件
举报原因:
原因补充:

(最多只允许输入30个字)